您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

MySQL按“最佳匹配”排序

MySQL按“最佳匹配”排序

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

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 2022/1/1 18:13:43 有615人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶