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);

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

相关推荐

  1. mysql中文字母排序查询

    2024-02-20 18:26:02       51 阅读
  2. 4k stars! 如何实现按拼音字母查询证券代码?

    2024-02-20 18:26:02       38 阅读
  3. mysql建立支持中文字符的库

    2024-02-20 18:26:02       32 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-20 18:26:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-20 18:26:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-02-20 18:26:02       82 阅读
  4. Python语言-面向对象

    2024-02-20 18:26:02       91 阅读

热门阅读

  1. 理解C++中仿函数(函数对象)中的状态保持

    2024-02-20 18:26:02       48 阅读
  2. 【Qt笔记】QSS中常见的伪状态

    2024-02-20 18:26:02       46 阅读
  3. css中, grid-auto-rows: 怎样简写在grid:中

    2024-02-20 18:26:02       45 阅读
  4. Flink容错机制

    2024-02-20 18:26:02       50 阅读
  5. 分享15个基本且常用Pandas代码(建议收藏)

    2024-02-20 18:26:02       43 阅读
  6. 零基础学c++(第二节)

    2024-02-20 18:26:02       49 阅读
  7. 时序数据库TDengine窗口函数

    2024-02-20 18:26:02       45 阅读