mysql中文首字母排序查询

MySQL中的排序涉及到字符集和排序规则。默认情况下,MySQL按照ASCII码对字符进行排序,数字>字母>中文。但是,特殊字符(非字母、数字、中文)的排序需要一些额外处理。
试过SUBSTRING、LEFT等,都不能完美实现多中文的首字母排序

以下是实现不同类型字符排序的示例:

  1. 单字符匹配实现:
SELECT name,
       (CASE WHEN HEX(name) REGEXP '[46][1-9]|[357][0-9]|[46][a-f]|[57]a|e[4-9][0-9a-f]{4}'
             THEN 0
             ELSE 1
        END) AS sort
FROM user
ORDER BY sort, CONVERT(name USING bgk);

匹配到非字母数字中文的内容,做排序,字母数字中文为null,排序优先级最高,排在上面。
为什么用HEX()函数做十六进制编码?因为中文用常规的正则不能匹配到结果。
为什么要把字母数字中文放在一起匹配?因为处理复杂度会更高。

  1. 多字符串实现:
    将name字段拆分为10个单字符,然后逐字进行匹配。
    修改正则表达式,匹配多个字符:
SELECT name,
       (CASE WHEN HEX(name) REGEXP '^[46][1-9]|[357][0-9]|[46][a-f]|[57]a|e[4-9][0-9a-f]{4}+'
             THEN 0
             ELSE 1
        END) AS sort
FROM user
ORDER BY sort, CONVERT(name USING bgk);

这样可以处理更复杂的排序需求。

  • 7
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值