这个查询有问题吗?这个有时有效,有时无效。例如,对于“七”这个词,它不会返回任何分数,但我知道它至少出现在正文中的 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
编辑:我注意到“七”是停用词。还有其他方法吗? stopwords
最佳答案
在每个分数周围添加 COALESCE(value,0)。
关于mysql - 反对不归还分数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5915767/