SELECT * FROM data_1 WHERE MATCH (毕业学校,家庭住址) AGAINST ('"交通大学" "北京" "西安"' IN BOOLEAN MODE)
很奇怪的一个问题,为什么这条语句返回的数据有很多(90%以上)没有一个字段里面的数据包含交通大学、北京、西安三个关键词的。我实在是看不出为什么会返回这些结果。
这条语句的意思应该是全文搜索毕业学校,家庭住址两个字段,只要任何一个字段包含交通大学、北京、西安三个关键词,就算符合。为此我还专门给关键词打上了双引号,可就这也返回一堆没相关的数据,真实无语了。。

php7+mysql8中使用MATCH AGAINST进行搜索时的怪问题。
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- a7464553 2023-01-22 20:58关注
可能是查询语句有问题,可以尝试把毕业学校,家庭住址两个字段分开,比如:
SELECT * FROM data_1 WHERE MATCH (毕业学校) AGAINST ('"交通大学"' IN BOOLEAN MODE) OR MATCH (家庭住址) AGAINST ('"北京" "西安"' IN BOOLEAN MODE)
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报