继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

MySQL为什么不支持中文排序?

程序员阿牛
关注TA
已关注
手记 3
粉丝 1
获赞 1

前言

或许都知道,MySQL不支持中文排序,这样的说法可以说对也可以说也不对。接下来我们分析一下:

首先执行命令,查看编码集:

SHOW VARIABLES LIKE 'character_set%';

可以看到字符集是utf8mb4,这个字符集是市面上比较使用非常多的字符集

file

我们再看下,这个字符集对应的排序规则有哪些?

show collation like 'utf8mb4%';

file
图中可以看到,utf8mb4有很多的排序规则,比如说通用的uft8mb4_general_ci,瑞典文比较规则utf8mb4_swedish_ci等等,但是就是没有中文的比较规则,这也是为什么utf8mb4字符集不支持中文排序的原因。

事例:

select * from area_code order by province_name;

file
从图中可以看出,排序是不生效的

如果要按照中文排序。需要对字段编码进行转换,如下操作:

select * from area_code order by CONVERT(province_name USING gbk);

file

可以看到,转成gbk方式就可以排序了,原因是在gbk字符集下,排序规则支持中文排序,如下图:
file

因此说,MySQL不支持中文排序,可以说对,也可以说不对。

完结


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP