iou3344 2023-01-22 20:46 采纳率: 84.1%
浏览 48
已结题

php7+mysql8中使用MATCH AGAINST进行搜索时的怪问题。

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

  • 写回答

1条回答 默认 最新

  • a7464553 2023-01-22 20:58
    关注

    可能是查询语句有问题,可以尝试把毕业学校,家庭住址两个字段分开,比如:

    SELECT * FROM data_1 WHERE MATCH (毕业学校) AGAINST ('"交通大学"' IN BOOLEAN MODE) OR MATCH (家庭住址) AGAINST ('"北京" "西安"' IN BOOLEAN MODE)

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 1月31日
  • 已采纳回答 1月23日
  • 创建了问题 1月22日