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

讓MySQL支撐中文排序的完成辦法

編輯:MySQL綜合教程

讓MySQL支撐中文排序的完成辦法。本站提示廣大學習愛好者:(讓MySQL支撐中文排序的完成辦法)文章只能為提供參考,不一定能成為您想要的結果。以下是讓MySQL支撐中文排序的完成辦法正文


讓MySQL支撐中文排序

編繹MySQL時普通以ISO-8859字符集作為默許的字符集,是以在比擬進程中中文編碼字符年夜小寫轉換形成了這類景象,一種處理辦法是關於包括中文的字段加上"binary"屬性,使之作為二進制比擬,
例如將"name char(10)"改成"name char(10)binary"。
編譯MySQL時應用--with--charset=gbk 參數,如許MySQL就會直接支撐中文查找和排序了。

mysql order by 中文 排序

在MySQL中,我們常常會對一個字段停止排序查詢,但停止中文排序和查找的時刻,對漢字的排序和查找成果常常都是毛病的。 這類情形在MySQL的許多版本中都存在。
假如這個成績不處理,那末MySQL將沒法現實處置中文。 湧現這個成績的緣由是由於MySQL在查詢字符串時是年夜小寫不敏感的,在編繹MySQL時普通以ISO-8859字符集作為默許的字符集,是以在比擬進程中中文編碼字符年夜小寫轉換形成了這類景象。
處理辦法:
關於包括中文的字段加上"binary"屬性,使之作為二進制比擬,例如將"name char(10)"改成"name char(10)binary"。
假如你應用源碼編譯MySQL,可以編譯MySQL時應用 --with--charset=gbk 參數,如許MySQL就會直接支撐中文查找和排序了(默許的是latin1)。也能夠用 extra-charsets=gb2312,gbk 來參加多個字符集。
假如不想對表構造停止修正或許從新編譯MySQL,也能夠在查詢語句的 order by 部門應用 CONVERT 函數。好比 select * from mytable order by CONVERT(chineseColumnName USING gbk);

UTF8 默許校訂集是 utf8_general_ci , 它不是依照中文來的。你須要強迫讓MySQL按中文來排序。

select * from core_vender_info order by convert(vender_abbrev USING gbk) COLLATE gbk_chinese_ci
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved