当前位置:Gxlcms > 数据库问题 > mysql 汉字根据首字母排序

mysql 汉字根据首字母排序

时间:2021-07-01 10:21:17 帮助过:18人阅读

1:如果数据库表字段的字符编码是latin1_swedish_ci

select * from tablename order by birary(name) asc ;
tablename:数据库表名
name:排序字段名
birary不是函数,是类型转换运算符,它用来强制它后面的字符串为一个二进制字符串,可以理解为在字符串比较的时候区分大小写

2:如果数据库表字段的字符编码是utf8_general_ci(常用)

select * from tablename WHERE 1=1 order by CONVERT( name USING gbk ) COLLATE gbk_chinese_ci ASC
首先,对name字段进行gbk编码,然后,对编码后的内容根据gbk_chinese_ci进行整理排序。这样得到的结果,英文是排在中文前面的,而且是根据拼音排序的。

tablename:数据库表名
name:排序字段名
CONVERT:提供一个在不同字符集之间转换数据的方法。
COLLATE:COLLATE是一个算法语句,主要用于对字符进行排序,经常出现在表的创建语句中。sql语句里面的COLLATE主要用于对字符进行排序。
---------------------
版权声明:本文为CSDN博主「天才小小布」的原创文章,遵循CC 4.0 by-sa版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/w410589502/article/details/58049091

mysql 汉字根据首字母排序

标签:sel   之间   order   字母   sql语句   现在   tps   英文   天才   

人气教程排行