前言 或许都知道,Mysql不支持中文排序,这样的说法可以说对也可以说也不对。接下来我们分析一下: 首先执行命令,查看编码集: SHOW VARIABLES LIKE "character_set%"; 可以看到字符集是utf8mb4,
或许都知道,Mysql不支持中文排序,这样的说法可以说对也可以说也不对。接下来我们分析一下:
SHOW VARIABLES LIKE "character_set%";
可以看到字符集是utf8mb4,这个字符集是市面上比较使用非常多的字符集
show collation like "utf8mb4%";
图中可以看到,utf8mb4有很多的排序规则,比如说通用的uft8mb4_general_ci,瑞典文比较规则utf8mb4_swedish_ci等等,但是就是没有中文的比较规则,这也是为什么utf8mb4字符集不支持中文排序的原因。
事例:
select * from area_code order by province_name;
从图中可以看出,排序是不生效的
如果要按照中文排序。需要对字段编码进行转换,如下操作:
select * from area_code order by CONVERT(province_name USING gbk);
可以看到,转成gbk方式就可以排序了,原因是在gbk字符集下,排序规则支持中文排序,如下图:
因此说,mysql不支持中文排序,可以说对,也可以说不对。
本文由博客一文多发平台 OpenWrite 发布!
--结束END--
本文标题: MySQL为什么不支持中文排序?
本文链接: https://www.lsjlt.com/news/8645.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-05-12
2024-05-12
2024-05-12
2024-05-12
2024-05-12
2024-05-12
2024-05-12
2024-05-11
2024-05-11
2024-05-11
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0