MySQL中的排序規(guī)則
1. 什么是排序規(guī)則
在新建 MySQL 數(shù)據(jù)庫(kù)或表的時(shí)候經(jīng)常會(huì)選擇字符集和排序規(guī)則。
數(shù)據(jù)庫(kù)用的字符集大家都知道是怎么回事, 那排序規(guī)則是什么呢?
排序規(guī)則:
是指對(duì)指定字符集下不同字符的比較規(guī)則。
其特征有以下幾點(diǎn)
- 兩個(gè)不同的字符集不能有相同的排序規(guī)則
- 兩個(gè)字符集有一個(gè)默認(rèn)的排序規(guī)則有一些常用的命名規(guī)則。
- 如
_ci
結(jié)尾表示大小寫(xiě)不敏感 (caseinsensitive),_cs
表示大小寫(xiě)敏感 (case sensitive),_bin
表示二進(jìn)制的比較 (binary).
utf-8 有默認(rèn)的排序規(guī)則
命令: SHOW CHARSET LIKE 'utf8%';
區(qū)別:
utf8_general_ci
不區(qū)分大小寫(xiě), 這個(gè)你在注冊(cè)用戶名和郵箱的時(shí)候就要使用。utf8_general_cs
區(qū)分大小寫(xiě), 如果用戶名和郵箱用這個(gè) 就會(huì)照成不良后果utf8_bin
: 字符串每個(gè)字符串用二進(jìn)制數(shù)據(jù)編譯存儲(chǔ)。 區(qū)分大小寫(xiě), 而且可以存二進(jìn)制的內(nèi)容utf8_general_ci
校對(duì)速度快, 但準(zhǔn)確度稍差。utf8_unicode_ci
準(zhǔn)確度高, 但校對(duì)速度稍慢。
2. 對(duì)比
utf8_general_ci
不區(qū)分大小寫(xiě),utf8_general_cs
區(qū)分大小寫(xiě)utf8_bin
: compare strings by the binary value of each character in the string 將字符串每個(gè)字符串用二進(jìn)制數(shù)據(jù)編譯存儲(chǔ), 區(qū)分大小寫(xiě), 而且可以存二進(jìn)制的內(nèi)容。utf8_unicode_ci
校對(duì)規(guī)則僅部分支持 Unicode 校對(duì)規(guī)則算法, 一些字符還是不能支持;utf8_unicode_ci
不能完全支持組合的記號(hào)。
說(shuō)明: ci
是 case insensitive, 即 “大小寫(xiě)不敏感”, a
和 A
會(huì)在字符判斷中會(huì)被當(dāng)做一樣的。
bin
是二進(jìn)制, a
和 A
會(huì)別區(qū)別對(duì)待。
例如你運(yùn)行:
SELECT * FROM table WHERE txt = 'a'
那么在 utf8_bin
中你就找不到 txt = 'A'
的那一行, 而 utf8_general_ci
則可以。
utf8_general_ci
是一個(gè)遺留的 校對(duì)規(guī)則, 不支持?jǐn)U展, 它僅能夠在字符之間進(jìn)行逐個(gè)比較。
這意味著 utf8_general_ci
校對(duì)規(guī)則進(jìn)行的比較速度很快, 但是與使用 utf8_unicode_ci
的校對(duì)規(guī)則相比, 比較正確性較差。
3. 應(yīng)用上的差別
1.對(duì)于一種語(yǔ)言僅當(dāng)使用 utf8_unicode_ci
排序做的不好時(shí), 才執(zhí)行與具體語(yǔ)言相關(guān)的 utf8
字符集校對(duì)規(guī)則。
例如, 對(duì)于德語(yǔ)和法語(yǔ), utf8_unicode_ci
工作的很好, 因此不再需要為這兩種語(yǔ)言創(chuàng)建特殊的 utf8
校對(duì)規(guī)則。
2.utf8_general_ci
也適用與德語(yǔ)和法語(yǔ), 除了 ?
等于 s
, 而不是 ss
之外。
如果你的應(yīng)用能夠接受這些, 那么應(yīng)該使用 utf8_general_ci
, 因?yàn)樗俣瓤臁?/p>
否則, 使用 utf8_unicode_ci
, 因?yàn)樗容^準(zhǔn)確。
4. 使用
utf8_unicode_ci
比較準(zhǔn)確, utf8_general_ci
速度比較快。
通常情況下, 新建數(shù)據(jù)庫(kù)時(shí)一般選用 utf8_general_ci
就可以了。
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
MySQL 數(shù)據(jù)庫(kù) 索引和事務(wù)
這篇文章主要介紹了MySQL 數(shù)據(jù)庫(kù) 索引和事務(wù),索引是為了加速對(duì)表中數(shù)據(jù)行的檢索而創(chuàng)建的一種分散的存儲(chǔ)結(jié);事物是屬于計(jì)算機(jī)中一個(gè)很廣泛的概念,一般是指要做的或所做的事情,下面我們就一起進(jìn)入文章了解具體內(nèi)容吧2021-12-12在MySQL數(shù)據(jù)庫(kù)之間實(shí)現(xiàn)數(shù)據(jù)同步的配置步驟
本文介紹了六種常見(jiàn)的MySQL數(shù)據(jù)同步方法,包括主從復(fù)制、雙主復(fù)制、群集復(fù)制、使用第三方工具(如PerconaXtraBackup)和使用MySQLWorkbench進(jìn)行數(shù)據(jù)同步,以及編寫(xiě)自定義腳本進(jìn)行數(shù)據(jù)同步,每種方法都有其優(yōu)缺點(diǎn),需根據(jù)實(shí)際需求選擇,感興趣的朋友一起看看吧2025-02-02mysql運(yùn)行net start mysql報(bào)服務(wù)名無(wú)效的解決辦法
這篇文章主要為大家詳細(xì)介紹了mysql運(yùn)行net start mysql報(bào)服務(wù)名無(wú)效的解決辦法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01SQL使用復(fù)合索引實(shí)現(xiàn)數(shù)據(jù)庫(kù)查詢的優(yōu)化
這篇文章主要介紹了SQL使用復(fù)合索引實(shí)現(xiàn)數(shù)據(jù)庫(kù)查詢的優(yōu)化,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-05-05Windows mysql 雙向同步設(shè)置方法 詳細(xì)篇
如果你需要windows mysql 主、備機(jī)雙向同步環(huán)境,可按照以下步驟進(jìn)行操作2011-05-05