我有一个包含单词的表和一个输入字段,可使用实时搜索来搜索该表。当前,我使用以下查询来搜索表:
SELECT word FROM words WHERE word LIKE '%searchstring%' ORDER BY word ASC 有没有一种方法可以对结果进行排序,以使在单词开头找到字符串的字符串排在最前面,而在单词后面出现字符串的字符串排在最后呢?
例如:搜索“ hab ”当前返回
一个 lphabet ^ h升技 [R EHAB 但我想这样:
赞一下(首先是因为“赞”是开始) alp hab et(第二个原因是'hab'在单词的中间) re hab (最后是因为'hab'在单词的结尾) 或者至少这样:
赞一下(首先是因为“赞”是开始) re hab (第二个,因为“ hab”从第三个字母开始) alp hab 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 , word 在以开头的多个单词的情况下,以开头hab的单词hab将被分组在一起并按字母顺序排序。来源:stack overflow