MySQL 排序規(guī)則簡介
1. MySQL 排序規(guī)則
1.1. 什么是排序規(guī)則
在新建 MySQL 數(shù)據(jù)庫或表的時候經(jīng)常會選擇字符集和排序規(guī)則。數(shù)據(jù)庫用的字符集大家都知道是怎么回事, 那排序規(guī)則是什么呢?
排序規(guī)則: 是指對指定字符集下不同字符的比較規(guī)則。其特征有以下幾點(diǎn):
兩個不同的字符集不能有相同的排序規(guī)則兩個字符集有一個默認(rèn)的排序規(guī)則有一些常用的命名規(guī)則。如 _ci
結(jié)尾表示大小寫不敏感 (caseinsensitive), _cs
表示大小寫敏感 (case sensitive), _bin
表示二進(jìn)制的比較 (binary).
utf-8 有默認(rèn)的排序規(guī)則:
命令: SHOW CHARSET LIKE 'utf8%';
區(qū)別:
- utf8_general_ci 不區(qū)分大小寫, 這個你在注冊用戶名和郵箱的時候就要使用。
- utf8_general_cs 區(qū)分大小寫, 如果用戶名和郵箱用這個 就會照成不良后果
- utf8_bin: 字符串每個字符串用二進(jìn)制數(shù)據(jù)編譯存儲。 區(qū)分大小寫, 而且可以存二進(jìn)制的內(nèi)容
- utf8_general_ci 校對速度快, 但準(zhǔn)確度稍差。
- utf8_unicode_ci 準(zhǔn)確度高, 但校對速度稍慢。
1.2. 對比
- utf8_general_ci 不區(qū)分大小寫, utf8_general_cs 區(qū)分大小寫
- utf8_bin: compare strings by the binary value of each character in the string 將字符串每個字符串用二進(jìn)制數(shù)據(jù)編譯存儲, 區(qū)分大小寫, 而且可以存二進(jìn)制的內(nèi)容。
- utf8_unicode_ci 校對規(guī)則僅部分支持 Unicode 校對規(guī)則算法, 一些字符還是不能支持; utf8_unicode_ci 不能完全支持組合的記號。
說明: ci
是 case insensitive, 即 “大小寫不敏感”, a
和 A
會在字符判斷中會被當(dāng)做一樣的。 bin
是二進(jìn)制, a
和 A
會別區(qū)別對待。例如你運(yùn)行: SELECT * FROM table WHERE txt = 'a'
, 那么在 utf8_bin
中你就找不到 txt = 'A'
的那一行, 而 utf8_general_ci
則可以。 utf8_general_ci
是一個遺留的 校對規(guī)則, 不支持?jǐn)U展, 它僅能夠在字符之間進(jìn)行逐個比較。這意味著 utf8_general_ci
校對規(guī)則進(jìn)行的比較速度很快, 但是與使用 utf8_unicode_ci
的校對規(guī)則相比, 比較正確性較差。
1.3. 應(yīng)用上的差別
- 對于一種語言僅當(dāng)使用 utf8_unicode_ci 排序做的不好時, 才執(zhí)行與具體語言相關(guān)的 utf8 字符集校對規(guī)則。例如, 對于德語和法語, utf8_unicode_ci 工作的很好, 因此不再需要為這兩種語言創(chuàng)建特殊的 utf8 校對規(guī)則。
- utf8_general_ci 也適用與德語和法語, 除了 ? 等于 s, 而不是 ss 之外。如果你的應(yīng)用能夠接受這些, 那么應(yīng)該使用 utf8_general_ci, 因?yàn)樗俣瓤?。否則, 使用 utf8_unicode_ci, 因?yàn)樗容^準(zhǔn)確。
1.4. 使用
utf8_unicode_ci
比較準(zhǔn)確, utf8_general_ci
速度比較快。通常情況下, 新建數(shù)據(jù)庫時一般選用 utf8_general_ci
就可以了。
到此這篇關(guān)于MySQL 排序規(guī)則的文章就介紹到這了,更多相關(guān)MySQL 排序規(guī)則內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SQL中where語句的用法及實(shí)例代碼(條件查詢)
WHERE如需有條件地從表中選取數(shù)據(jù),可將WHERE 子句添加到SELECT語句,下面這篇文章主要給大家介紹了關(guān)于SQL中where語句的用法及實(shí)例(條件查詢)的相關(guān)資料,需要的朋友可以參考下2022-10-10mysql導(dǎo)入sql文件報錯 ERROR 2013 2006 2002
今天在做項(xiàng)目的時候遇到個問題,就是往mysql里導(dǎo)入sql文件的時候總是報ERROR 2013 2006 2002,研究了一番才找到解決辦法,這里記錄下來分享給大家2014-11-11MySql中的json_extract函數(shù)處理json字段詳情
這篇文章主要介紹了MySql中的json_extract函數(shù)處理json字段詳情,利用json_extract函數(shù)可以通過key查詢value值的一個介紹展開相關(guān)內(nèi)容,需要的小伙伴可以參考一下2022-06-06Linux下MySQL數(shù)據(jù)庫的主從同步復(fù)制配置
這篇文章主要介紹了Linux下MySQL數(shù)據(jù)庫的主從同步配置,2017-11-11