讓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