当前位置: 首页 > news >正文

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 0ELSE 1END) 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 0ELSE 1END) AS sort
FROM user
ORDER BY sort, CONVERT(name USING bgk);

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

相关文章:

  • 【PyQt】12-滑块、计数控件
  • Linux命令-netstat
  • Allegro172版本如何用自带功能改变过孔网络属性操作指导
  • [计算机网络]---Https协议
  • 探秘Java反射:灵活编程的利器
  • redis 主从模式,sentinel 模式配置
  • 使用Sora部署实时音视频通信应用实战项目
  • 代码随想录算法训练营第三十七天 738.单调递增的数字 、 968.监控二叉树 (跳过)
  • vue2中vuex的各项的各种调用方式,部分对比vue3的pinia
  • 【Redis,Java】Redis的两种序列化方式—nosql数据库
  • leetcode 01背包问题
  • Recorder 实现语音录制并上传到后端(兼容PC和移动端)
  • unity学习(15)——服务器组装(1)
  • LeetCode 0590. N 叉树的后序遍历:深度优先搜索(DFS)
  • 课后延时服务选课报名管理系统功能清单
  • PHP那些事儿
  • Redash本地开发环境搭建
  • windows下如何用phpstorm同步测试服务器
  • 精益 React 学习指南 (Lean React)- 1.5 React 与 DOM
  • 开发基于以太坊智能合约的DApp
  • 批量截取pdf文件
  • 如何设计一个微型分布式架构?
  • 深度学习在携程攻略社区的应用
  • 微服务框架lagom
  • 微信如何实现自动跳转到用其他浏览器打开指定页面下载APP
  • 新手搭建网站的主要流程
  • media数据库操作,可以进行增删改查,实现回收站,隐私照片功能 SharedPreferences存储地址:
  • C# - 为值类型重定义相等性
  • 小白应该如何快速入门阿里云服务器,新手使用ECS的方法 ...
  • ​如何使用ArcGIS Pro制作渐变河流效果
  • #我与Java虚拟机的故事#连载13:有这本书就够了
  • (9)目标检测_SSD的原理
  • (理论篇)httpmoudle和httphandler一览
  • (论文阅读11/100)Fast R-CNN
  • (南京观海微电子)——I3C协议介绍
  • (四)c52学习之旅-流水LED灯
  • (原)Matlab的svmtrain和svmclassify
  • .bat批处理(一):@echo off
  • .cfg\.dat\.mak(持续补充)
  • .net core 控制台应用程序读取配置文件app.config
  • .NET NPOI导出Excel详解
  • .net websocket 获取http登录的用户_如何解密浏览器的登录密码?获取浏览器内用户信息?...
  • .net 调用php,php 调用.net com组件 --
  • .NET 使用 ILMerge 合并多个程序集,避免引入额外的依赖
  • .net 逐行读取大文本文件_如何使用 Java 灵活读取 Excel 内容 ?
  • .NET单元测试
  • .NET的微型Web框架 Nancy
  • .net反编译工具
  • .NET牛人应该知道些什么(2):中级.NET开发人员
  • .Net下C#针对Excel开发控件汇总(ClosedXML,EPPlus,NPOI)
  • .project文件
  • @Service注解让spring找到你的Service bean
  • [ 渗透测试面试篇 ] 渗透测试面试题大集合(详解)(十)RCE (远程代码/命令执行漏洞)相关面试题
  • [Angular] 笔记 8:list/detail 页面以及@Input
  • [CLR via C#]11. 事件