最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

MySQL中的utf8中文排序的解决方案

来源:动视网 责编:小采 时间:2020-11-09 12:31:00
文档

MySQL中的utf8中文排序的解决方案

MySQL中的utf8中文排序的解决方案:在MySQL中使用默认字符集为utf8,结果想要把中文按拼音排序出现了问题,排出来的顺序乱七八糟,不是我们想要的结果。解决方案如下:1、不想 在MySQL中使用默认字符集为utf8,结果想要把中文按拼音排序出现了问题,排出来的顺序乱七八糟,不是我们想要的结果
推荐度:
导读MySQL中的utf8中文排序的解决方案:在MySQL中使用默认字符集为utf8,结果想要把中文按拼音排序出现了问题,排出来的顺序乱七八糟,不是我们想要的结果。解决方案如下:1、不想 在MySQL中使用默认字符集为utf8,结果想要把中文按拼音排序出现了问题,排出来的顺序乱七八糟,不是我们想要的结果


在MySQL中使用默认字符集为utf8,结果想要把中文按拼音排序出现了问题,排出来的顺序乱七八糟,不是我们想要的结果。解决方案如下:1、不想

在MySQL中使用默认字符集为utf8,结果想要把中文按拼音排序出现了问题,排出来的顺序乱七八糟,不是我们想要的结果。

解决方案如下:

1、不想改变表定义及默认编码的情况,将字段先转换成gbk编码再排序:

SELECT * FROM table ORDER BY CONVERT( chinese_field USING gbk ) ;

前提是在安装MySQL时安装了gbk字符集,不然会报错:

#1115 - Unknown character set: 'gbk'

在编译源码时加上gbk编码即可,如果已经安装好了,重新编译再安装,重新编译安装一般不会影响MySQL的已有设置,,包括数据都不会受到影响。

2、直接将字段的字符集改成gbk,然后直接使用order by 排序即可。

MySQL 5.x支持某列单独定义字符集。

3、网上也有人说将字段定义加上binary属性也能达到效果,未作测试,不敢评论。

MySQL的文档中也提到字符集校对规则:

SELECT * FROM t1 ORDER BY a COLLATE utf8_bin;

但此仅仅只影响校对规则,并不影响字符的字符集本身。

文档

MySQL中的utf8中文排序的解决方案

MySQL中的utf8中文排序的解决方案:在MySQL中使用默认字符集为utf8,结果想要把中文按拼音排序出现了问题,排出来的顺序乱七八糟,不是我们想要的结果。解决方案如下:1、不想 在MySQL中使用默认字符集为utf8,结果想要把中文按拼音排序出现了问题,排出来的顺序乱七八糟,不是我们想要的结果
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top