关于 MySQL 中文排序问题

在 MySQL 数据库中使用 UTF-8 的编码进行排序会出现不按照中文拼音的顺序排序,
而 UTF-8 是数据库的默认字符集,而且该字符集忽略大小写。解决这个问题的方案
有两种:
1) 把编码重新设定为 GBK 或者 GB2312,数据库重设编码是个大问题显然不能这
样使用
2) 使用 convert()函数实现临时编码,查询语句例如:
正序:
select * from table_name ORDER BY CONVERT(name USING gbk);
倒序:
select * from table_name ORDER BY CONVERT(name USING gb2312) desc.
根据项目情况自行决定修改字段字符集还是通过 CONVERT 函数进行编码转换,建议数据量
少的情况可以考虑第二种方案在内存进行排序方式解决,数据量多的话建议第一种
方式

posted @ 2023-02-28 09:04  何童鞋  阅读(142)  评论(0编辑  收藏  举报