0

这是我执行搜索的代码

 SELECT d.deal_id,
    d.deal_title,
    d.friendly_url
    FROM wp_deals AS d
   WHERE MATCH (d.deal_title) AGAINST ('Historic China eight day tour' IN BOOLEAN MODE)
   GROUP BY d.deal_id

它工作正常。并给出 14 个结果。其中之一是

大桑迪海峡两晚自然邂逅之旅,包括日落巡游等。最高减$1,071!

但是当我搜索“with”或“more”时,它变成了

SELECT d.deal_id,
   d.deal_title,
   d.friendly_url
 FROM wp_deals AS d
WHERE MATCH (d.deal_title) AGAINST ('more' IN BOOLEAN MODE)
GROUP BY d.deal_id


 SELECT d.deal_id,
   d.deal_title,
   d.friendly_url
   FROM wp_deals AS d
   WHERE MATCH (d.deal_title) AGAINST ('with' IN BOOLEAN MODE)
   GROUP BY d.deal_id

并且没有给出任何结果,尽管两者都是他们的。我不是这类搜索查询的专家。

当我用“旅游”搜索时,这也是他们的工作正常。他们发生了什么。不能理解为“tour”、“with”和“more”都包含四个字母以及它们的标题。

你们是天才..

你的建议,所以它会锻炼。

提前致谢。

4

1 回答 1

0

在布尔全文搜索中,停用词列表适用,常用词(例如“some”或“then”...)是停用词,如果搜索字符串中存在则不匹配:http: //dev.mysql.com/doc/ refman/5.5/en//fulltext-boolean.html

停用词列表:http ://dev.mysql.com/doc/refman/5.0/en/fulltext-stopwords.html

最著名的解决方案是禁用列表或从中添加/删除值:如何在 MYSQL 中重置停用词?

还 :

SELECT d.deal_id,
   d.deal_title,
   d.friendly_url
FROM 
   wp_deals AS d
WHERE MATCH (d.deal_title) AGAINST ('+more*' IN BOOLEAN MODE)
GROUP BY d.deal_id
于 2013-01-11T07:31:54.400 回答