程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> MySQL中文排序錯誤的解決方法

MySQL中文排序錯誤的解決方法

編輯: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.bKjia.c0m');
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編碼就可以了

*/
?>

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved