MySQL 按首字母排序

如果,mysql字段中的内容是全英文的,那么排序直接常规排序ASC DESC ASC 正序 DESC倒叙 ,就可以。
如果想要排中文的汉字,其实是按着拼音排序
通常我们在查询书籍时,会出现按照书籍的名称进行排序,由于一般数据库编码大都为utf-8 ,他的排序方式为按英文字母规则排序 "a,b,c… "
在这里插入图片描述
由上表看出,只要我们在排序时将需要排序的字段转化为GBK编码再进行排序,就可以实现按照书籍名称的首字母进行排序了, 怎样才能将编码转化为GBK呢?在MySQL中提供了函数CONVERT() ,该函数可用来获取一个类型的值

该函数的使用方式为 CONVERT(字段 USING GBK)

例如:

SELECT * FROM table ORDER BY CONVERT(field USING GBK) ASC

如果表字段使用的GBK编码的话,我们可以直接order by value ,因为GBK本身就是按照拼音字母排序ABCDEFGHIGK…,当第一位相同的时候会比较第二位,以此类推。

如果表字段使用的UTF-8编码的话,通常我们都会的编码,这样我们可以使用MySQL的convert方法开转换gbk进行排序。

SELECT * FROM TEST ORDER BY CONVERT(value USING GBK) ASC/DESC

发布了7 篇原创文章 · 获赞 11 · 访问量 8万+

猜你喜欢

转载自blog.csdn.net/dxyzhbb/article/details/104047547