设为首页 加入收藏

TOP

MySQL中文排序错误的解决方法
2011-06-12 21:36:37 来源: 作者: 【 】 浏览:72次 评论:0

MySQL中文排序错误的解决方法
/*

方法一

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

mysql教程 5.x支持某列单独定义字符集

方法二

对于包含中文的字段加上"binary"属性,使之作为二进制比较,例如将"name char(10)"改成"name char(10)binary"。
如果你使用源码教程编译MySQL,可以编译MySQL时使用 --with--charset=gbk 参数,这样MySQL就会直接支持中文查找和排序了(默认的是latin1)。也可以用 extra-charsets=gb2312,gbk 来加入多个字符集

下面来看个实例

1)test1:
CREATE TABLE `test1` (                                 
          `id` int(4) unsigned NOT NULL auto_increment,       
          `name` varchar(20) character set utf8 default NULL,
          PRIMARY KEY (`id`)                                 
        ) ;

insert into `test1` (`id`, `name`) values('1','邓www.111cn.net');
insert into `test1` (`id`, `name`) values('2','李');
insert into `test1` (`id`, `name`) values('3','江');
insert into `test1` (`id`, `name`) values('4','胡');

select name from test1 order by name;

得出的结果是不正确的,现在我们用

test1表中的数据没有按照中文拼音排序,而使用了gbk字符集的test2查询结果令人很满意。

select * from core_vender_info order by convert(vender_abbrev USING gbk) COLLATE gbk_chinese_ci

查询的时候,通过convert函数,把查询出来的数据使用的字符集gb2312编码就可以了

*/
?>

您看到此篇文章时的感受是:
Tags: 责任编辑:administrator
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到QQ空间
分享到: 
上一篇mysql 数据库备份代码 下一篇sql 如何从百万条记录中删除某会..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

相关栏目

最新文章

图片主题

热门文章

推荐文章

相关文章

广告位