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

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日

悬赏问题

  • ¥15 linux驱动,linux应用,多线程
  • ¥20 我要一个分身加定位两个功能的安卓app
  • ¥15 基于FOC驱动器,如何实现卡丁车下坡无阻力的遛坡的效果
  • ¥15 IAR程序莫名变量多重定义
  • ¥15 (标签-UDP|关键词-client)
  • ¥15 关于库卡officelite无法与虚拟机通讯的问题
  • ¥15 目标检测项目无法读取视频
  • ¥15 GEO datasets中基因芯片数据仅仅提供了normalized signal如何进行差异分析
  • ¥100 求采集电商背景音乐的方法
  • ¥15 数学建模竞赛求指导帮助