首頁 > 軟體

MySQL校對規則(COLLATION)的具體使用

2022-08-09 18:00:17

簡介

本文介紹MySQL的校對規則。

MySQL的校對規則

  • 兩個不同的字元集不能有相同的校對規則。
  • 每個字元集有一個預設校對規則。例如:
    • utf8mb4預設校對規則:utf8mb4_general_ci。
    • utf8預設校對規則:utf8_general_ci。
  • 存在校對規則命名約定:它們以其相關的字元集名開始,通常包括一個語言名,並且以_ci(大小寫不敏感)、_cs(大小寫敏感)或_bin(二進位制,大小寫敏感)結束。

校對規則列舉 

  • utf8mb4_general_ci
  • utf8mb4_unicode_ci
  • utf8mb4_general_cs
  • utf8mb4_bin

//不存在utf8_unicode_cs

檢視校對規則

檢視支援的校驗規則

mysql> SHOW COLLATION like 'utf8%';
+--------------------------+---------+-----+---------+----------+---------+
| Collation                | Charset | Id  | Default | Compiled | Sortlen |
+--------------------------+---------+-----+---------+----------+---------+
| utf8_general_ci          | utf8    |  33 | Yes     | Yes      |       1 |
| utf8_bin                 | utf8    |  83 |         | Yes      |       1 |
| utf8_unicode_ci          | utf8    | 192 |         | Yes      |       8 |
...
| utf8mb4_general_ci       | utf8mb4 |  45 | Yes     | Yes      |       1 |
| utf8mb4_bin              | utf8mb4 |  46 |         | Yes      |       1 |
| utf8mb4_unicode_ci       | utf8mb4 | 224 |         | Yes      |       8 |
| utf8mb4_icelandic_ci     | utf8mb4 | 225 |         | Yes      |       8 |

檢視原生的校驗規則

mysql> show global variables like '%coll%';
+----------------------+--------------------+
| Variable_name        | Value              |
+----------------------+--------------------+
| collation_connection | utf8mb4_unicode_ci |
| collation_database   | utf8mb4_unicode_ci |
| collation_server     | utf8mb4_unicode_ci |
+----------------------+--------------------+

修改校對規則

修改資料庫設定後,不會對已經存在的表造成影響,如要生效需要修改特定列的排序規則。優先順序:列>表>資料庫>伺服器。

對已存在的表修改

# 修改資料庫:  
ALTER DATABASE database_name CHARACTER SET = utf8mb4 COLLATE = utf8mb4_bin;  
# 修改表:  
ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_bin;  
# 修改表欄位:  
ALTER TABLE table_name CHANGE column_name column_name VARCHAR(191) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NOT NULL ; 

建立表時指定

CREATE TABLE `T` (
  `name` varchar(20) COLLATE utf8mb4_unicode_ci DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci

utf8_general_ci 與 utf8_unicode_ci區別

utf8mb4_unicode_ciutf8mb4_general_ci總結
準確性基於標準的Unicode來排序和比較,能夠在各種語言之間精確排序沒有實現Unicode排序規則,在遇到某些特殊語言或字元時,排序結果可能不是所期望的。絕大多數情況下,特殊字元的順序不需要那麼精確。
效能在特殊情況下,Unicode排序規則為了能夠處理特殊字元的情況,實現了略微複雜的排序演演算法。在比較和排序的時候更快

絕大多數情況下,不會發生此類複雜比較。

總結:

utf8_unicode_ci比較準確,utf8_general_ci速度比較快。

通常情況下 utf8_general_ci 的準確性就夠我們用的了,在我看過很多程式原始碼後,發現它們大多數也用的是utf8_general_ci,所以新建資料 庫時一般選用utf8_general_ci就可以了。

如果是utf8mb4那麼對應的就是 utf8mb4_general_ci utf8mb4_unicode_ci

到此這篇關於MySQL校對規則(COLLATION)的具體使用的文章就介紹到這了,更多相關MySQL 校對規則內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com