mysql精准匹配和模糊匹配排序问题

背景:

对数据库中商品名称匹配,比如 `蜂蜜`,查询结果默认id升序排列,导致想要的结果并不一定在前面

解决:

复制代码

SELECT NAME
FROM
  goods
WHERE
  STATUS = 1
AND (
  NAME = #{keyword}
  OR NAME LIKE concat(
    concat('%',#{keyword}), '%'))
ORDER BY
  CHAR_LENGTH( NAME ),id
LIMIT 10

复制代码

注意:

mysql中如果对字母匹配,看当前表的字符集,CHARSET=utf8mb4是不区分大小写的

posted @   白玉神驹  阅读(64)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统
· 【译】Visual Studio 中新的强大生产力特性
· 2025年我用 Compose 写了一个 Todo App
点击右上角即可分享
微信分享提示