MySQL?排序規(guī)則Collation實例詳解
在 MySQL 中,排序規(guī)則(Collation)是控制字符比較方式的核心機制,直接影響查詢結(jié)果的排序、匹配邏輯(如大小寫區(qū)分)等。本文將從基礎(chǔ)概念出發(fā),詳解排序規(guī)則的作用、與字符集的關(guān)系、查看與配置方法,并通過實際案例說明其對查詢結(jié)果的影響,幫助開發(fā)者精準控制數(shù)據(jù)匹配行為。
一、排序規(guī)則的核心概念
排序規(guī)則(Collation)是字符集(Character Set)的 "配套規(guī)則",定義了字符之間的比較、排序邏輯。其核心作用體現(xiàn)在兩個維度:
- 大小寫區(qū)分:是否將
'a'和'A'視為相同字符; - 編碼適配:針對特定字符集(如 UTF-8)的語言特性(如 accents 字符)制定比較規(guī)則。
 
例如,UTF-8 字符集的utf8mb4_0900_ai_ci排序規(guī)則中:
ai表示 "accent-insensitive"(忽略重音);ci表示 "case-insensitive"(忽略大小寫);
而utf8mb4_0900_as_cs中,as(accent-sensitive)和cs(case-sensitive)則表示區(qū)分重音和大小寫。
二、字符集與排序規(guī)則的關(guān)聯(lián)
字符集與排序規(guī)則是 "一對多" 的關(guān)系:一個字符集可以對應(yīng)多個排序規(guī)則,但每個排序規(guī)則僅屬于一個字符集。兩者的默認關(guān)聯(lián)規(guī)則如下:
- 若僅指定字符集,排序規(guī)則將使用該字符集的默認值(如
utf8mb4默認排序規(guī)則為utf8mb4_0900_ai_ci); - 若僅指定排序規(guī)則,字符集將自動匹配該排序規(guī)則對應(yīng)的字符集(如指定
utf8mb4_general_ci,字符集即為utf8mb4)。 
三、排序規(guī)則的查看與配置
1. 查看字符集與排序規(guī)則信息
查看所有字符集及其默認排序規(guī)則:
-- 方法1:SHOW命令 SHOW CHARACTER SET; -- 方法2:查詢系統(tǒng)表 SELECT * FROM INFORMATION_SCHEMA.CHARACTER_SETS;
查看指定字符集的所有排序規(guī)則:
-- 查看utf8mb4字符集的所有排序規(guī)則 SHOW COLLATION WHERE Charset = 'utf8mb4';
查看數(shù)據(jù)庫的默認字符集與排序規(guī)則:
-- 方法1:使用系統(tǒng)變量 USE test_db; -- 切換到目標數(shù)據(jù)庫 SELECT @@character_set_database, @@collation_database; -- 方法2:查詢系統(tǒng)表 SELECT DEFAULT_CHARACTER_SET_NAME, DEFAULT_COLLATION_NAME FROM INFORMATION_SCHEMA.SCHEMATA WHERE SCHEMA_NAME = 'test_db'; -- 替換為數(shù)據(jù)庫名
2. 不同對象的排序規(guī)則設(shè)置
MySQL 中,排序規(guī)則可在服務(wù)器、數(shù)據(jù)庫、表、列、字符串五個層級設(shè)置,下層默認繼承上層配置(可單獨覆蓋)。
| 對象 | 字符集設(shè)置方式 | 排序規(guī)則設(shè)置方式 | 說明 | 
|---|---|---|---|
| 服務(wù)器 | character_set_server 系統(tǒng)變量 | collation_server 系統(tǒng)變量 | 未指定時,數(shù)據(jù)庫默認繼承服務(wù)器配置 | 
| 數(shù)據(jù)庫 | 建庫時 CHARACTER SET 子句 | 建庫時 COLLATE 子句 | 未指定時,表默認繼承數(shù)據(jù)庫配置 | 
| 表 | 建表時 CHARACTER SET 子句 | 建表時 COLLATE 子句 | 未指定時,列默認繼承表配置 | 
| 列 | 字段定義中 CHARACTER SET 子句 | 字段定義中 COLLATE 子句 | 最細粒度控制,直接影響字段查詢邏輯 | 
| 字符串常量 | SELECT _utf8mb4'abc' | SELECT 'abc' COLLATE utf8mb4_general_ci | 臨時指定,覆蓋連接級別的默認規(guī)則 | 
四、排序規(guī)則對查詢結(jié)果的影響
排序規(guī)則不影響數(shù)據(jù)存儲(存入的'a'和'A'會原樣保存),但直接決定查詢時的匹配邏輯。以下通過測試案例驗證:
測試環(huán)境
- MySQL 版本:8.0.28
 - 測試表:
test_db.a(字段i為char(1)類型) 
案例 1:忽略大小寫的排序規(guī)則(utf8mb4_0900_ai_ci)
-- 設(shè)置字段排序規(guī)則為忽略大小寫
ALTER TABLE test_db.a CHANGE i i CHAR(1) COLLATE utf8mb4_0900_ai_ci;
-- 插入數(shù)據(jù)
INSERT INTO test_db.a VALUES ('a'), ('A');
-- 查詢:條件為'i = 'a''
SELECT * FROM test_db.a WHERE i = 'a'; 
-- 結(jié)果:返回'a'和'A'(兩者被視為相同)案例 2:區(qū)分大小寫的排序規(guī)則(utf8mb4_0900_as_cs)
-- 設(shè)置字段排序規(guī)則為區(qū)分大小寫
ALTER TABLE test_db.a CHANGE i i CHAR(1) COLLATE utf8mb4_0900_as_cs;
-- 插入數(shù)據(jù)(同上)
INSERT INTO test_db.a VALUES ('a'), ('A');
-- 查詢:條件為'i = 'a''
SELECT * FROM test_db.a WHERE i = 'a'; 
-- 結(jié)果:僅返回'a'(嚴格區(qū)分大小寫)結(jié)論
- 字段的排序規(guī)則直接決定查詢時的字符匹配邏輯;
 - 若需查詢時區(qū)分大小寫,需將字段排序規(guī)則設(shè)置為
*_cs(case-sensitive)類型; - 若需忽略大小寫,使用
*_ci(case-insensitive)類型。 
五、實踐建議
明確大小寫需求:根據(jù)業(yè)務(wù)場景選擇排序規(guī)則。例如,用戶名通常需要區(qū)分大小寫(用
*_cs),而商品名稱可能忽略大小寫(用*_ci)。統(tǒng)一配置層級:建議在數(shù)據(jù)庫或表級別統(tǒng)一設(shè)置排序規(guī)則,避免列級別配置混亂(特殊字段單獨覆蓋)。
查詢時臨時覆蓋:如需臨時改變匹配邏輯,可在查詢中指定排序規(guī)則:
-- 臨時按區(qū)分大小寫查詢(即使字段默認不區(qū)分) SELECT * FROM test_db.a WHERE i COLLATE utf8mb4_0900_as_cs = 'a';
注意連接級影響:客戶端連接的
collation_connection變量會影響字符串常量的匹配邏輯,若需一致行為,建議在字段級別顯式指定排序規(guī)則。
總結(jié)
MySQL 排序規(guī)則是控制字符比較邏輯的關(guān)鍵機制,其核心作用體現(xiàn)在查詢階段的匹配與排序行為。通過理解字符集與排序規(guī)則的關(guān)聯(lián)、掌握多層級配置方法,并結(jié)合業(yè)務(wù)場景選擇合適的規(guī)則(如區(qū)分 / 忽略大小寫),可確保查詢結(jié)果符合預(yù)期,避免因字符匹配問題導(dǎo)致的業(yè)務(wù)異常。
到此這篇關(guān)于MySQL 排序規(guī)則Collation實例詳解的文章就介紹到這了,更多相關(guān)mysql排序規(guī)則內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
 詳解Ubuntu Server下啟動/停止/重啟MySQL數(shù)據(jù)庫的三種方式
本篇文章主要介紹了buntu Server下啟動/停止/重啟MySQL數(shù)據(jù)庫的三種方式,具有一定的參考價值,有興趣的可以了解一下。2017-01-01
 wampserver下mysql導(dǎo)入數(shù)據(jù)庫的步驟
這篇文章主要介紹了wampserver下mysql導(dǎo)入數(shù)據(jù)庫的步驟,需要的朋友可以參考下2016-08-08
 MySQL中order?by排序時數(shù)據(jù)存在null則排序在最前面的方法
order by排序是最常用的功能,但是排序有時會遇到數(shù)據(jù)為空null的情況,這樣排序就會亂了,這篇文章主要給大家介紹了關(guān)于MySQL中order?by排序時數(shù)據(jù)存在null則排序在最前面的相關(guān)資料,需要的朋友可以參考下2024-06-06
 Mysql使用on update current_timestamp問題
這篇文章主要介紹了Mysql使用on update current_timestamp問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03

