【www.gdgbn.com--mysql教程】
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编码就可以了
*/
?>