MySQL按“最佳匹配”排序

我有一个包含单词的表和一个输入字段,可使用实时搜索来搜索该表。当前,我使用以下查询来搜索表:

SELECT word FROM words WHERE word LIKE '%searchstring%' ORDER BY word ASC

有没有一种方法可以对结果进行排序,以使在单词开头找到字符串的字符串排在最前面,而在单词后面出现字符串的字符串排在最后呢?

例如:搜索“ ”当前返回

  1. lphabet
  2. 升技
  3. EHAB

但我想这样:

  1. 一下(首先是因为“赞”是开始)
  2. alp et(第二个原因是’hab’在单词的中间)
  3. re (最后是因为’hab’在单词的结尾)

或者至少这样:

  1. 一下(首先是因为“赞”是开始)
  2. re (第二个,因为“ hab”从第三个字母开始)
  3. alp et(最后一次是因为’hab’最晚在第四个字母开始)

如果有人可以帮我解决这个问题,那就太好了!

回答:

若要以第一方式进行操作(从单词的开头,单词的中间到单词的结尾),请尝试以下操作:

SELECT word

FROM words

WHERE word LIKE '%searchstring%'

ORDER BY

CASE

WHEN word LIKE 'searchstring%' THEN 1

WHEN word LIKE '%searchstring' THEN 3

ELSE 2

END

若要第二种方式(匹配字符串的位置),请使用以下LOCATE函数:

SELECT word

FROM words

WHERE word LIKE '%searchstring%'

ORDER BY LOCATE('searchstring', word)

您还可能需要决胜局,例如,多个单词以开头hab。为此,我建议:

SELECT word

FROM words

WHERE word LIKE '%searchstring%'

ORDER BY <whatever>, word

在以开头的多个单词的情况下,以开头hab的单词hab将被分组在一起并按字母顺序排序。

以上是 MySQL按“最佳匹配”排序 的全部内容, 来源链接: utcz.com/qa/411452.html

回到顶部