亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL中的排序規(guī)則

 更新時(shí)間:2023年11月24日 08:39:56   作者:云滿筆記  
這篇文章主要介紹了MySQL中的排序規(guī)則,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

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ě)不敏感”, aA 會(huì)在字符判斷中會(huì)被當(dāng)做一樣的。

bin 是二進(jìn)制, aA 會(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 整表加密解決方案 keyring_file詳解

    MySQL 整表加密解決方案 keyring_file詳解

    這篇文章主要介紹了MySQL 整表加密解決方案 keyring_file詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • 最新評(píng)論