1

这个查询有问题吗?这个有时有效,有时无效。例如,“七”这个词不会返回任何分数,但我知道它至少出现在正文中的 29 行上,但它返回分数 0。

换句话说,它工作正常,但不适用于这个。任何人都知道为什么或有不同的解决方案来按相关性对其进行排序?

   SELECT *, 
         ( (MATCH(articles.name) AGAINST('seven'))*5 +
           (MATCH(articles.subtitle) AGAINST('seven'))*3 + 
           (MATCH(articles.body) AGAINST('seven'))) AS search_score 
     FROM articles 
LEFT JOIN matches ON articles.match=matches.id 
 ORDER BY search_score DESC

编辑:我注意到“七”是一个停用词。还有其他方法可以做到这一点吗?停用词

4

2 回答 2

0

问题
如果单词太常见,即出现在 50%+ 的行中,MySQL 会认为它是 STOP-word,不会匹配它。
然后是停用词列表(您已经注意到了)
请参阅:http ://dev.mysql.com/doc/refman/5.5/en/fulltext-stopwords.html

解决方案
这个答案:在哪里编辑 mysql 全文停用词列表?
告诉您如何覆盖/替换默认停用词列表。

这是 MySQL 文档页面的链接:http: //dev.mysql.com/doc/refman/5.5/en/fulltext-fine-tuning.html

于 2011-05-06T19:21:07.713 回答
0

在每个分数周围添加 COALESCE(value,0)。

于 2011-05-06T18:54:49.850 回答