一尘不染

如何按相关性对MYSQL全文搜索结果进行排序

mysql

我对MYSQL相对较新,遇到了困扰我一段时间的问题。我已经尝试在所有地方使用Google搜索来寻找答案,但到目前为止仍无法找到可接受的解决方案。

这是我当前正在运行的查询,用于查找给定搜索词的最佳匹配项:

$query="SELECT * from `vocabulary` WHERE translation = 'word' OR translation LIKE '%word%'";

它返回的结果是全面的,因为它们包括所有相关的行。但是,它们没有按照任何特定的顺序排序,我希望在用PHP打印结果时首先显示完全匹配的匹配项。像这样:


1 | 字<精确匹配
2 | 填字游戏<-按字母顺序排序的部分匹配项/
3 | 字
4 | 文字匠


预先非常感谢您的协助。

-macspacejunkie


阅读 741

收藏
2020-05-17

共1个答案

一尘不染

SELECT * from vocabulary 
WHERE translation like 'word'  
union all
SELECT * from vocabulary 
WHERE translation LIKE '%word%' and translation not like 'word'

将首先列出完全匹配项

2020-05-17