欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL?排序規(guī)則Collation實例詳解

 更新時間:2025年07月21日 09:10:23   作者:數(shù)據(jù)派  
本文將從基礎(chǔ)概念出發(fā),詳解排序規(guī)則的作用、與字符集的關(guān)系、查看與配置方法,并通過實際案例說明其對查詢結(jié)果的影響,幫助開發(fā)者精準控制數(shù)據(jù)匹配行為,感興趣的朋友一起看看吧

在 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(字段ichar(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)文章

  • MySQL的安裝以及基本的管理命令和設(shè)置

    MySQL的安裝以及基本的管理命令和設(shè)置

    這篇文章主要介紹了MySQL的安裝以及基本的管理命令和設(shè)置,是搭建MySQL環(huán)境的基礎(chǔ),需要的朋友可以參考下
    2015-11-11
  • MySQL的mysqldump工具用法詳解

    MySQL的mysqldump工具用法詳解

    這篇文章主要介紹了MySQL的mysqldump工具用法詳解,同時附帶了相關(guān)Source命令的用法,詳解需要的朋友可以參考下
    2015-07-07
  • 詳解Ubuntu Server下啟動/停止/重啟MySQL數(shù)據(jù)庫的三種方式

    詳解Ubuntu Server下啟動/停止/重啟MySQL數(shù)據(jù)庫的三種方式

    本篇文章主要介紹了buntu Server下啟動/停止/重啟MySQL數(shù)據(jù)庫的三種方式,具有一定的參考價值,有興趣的可以了解一下。
    2017-01-01
  • MySQL DBA 常用手冊小結(jié)

    MySQL DBA 常用手冊小結(jié)

    MySQL DBA 常用手冊小結(jié),使用mysql的朋友可以參考下。
    2011-11-11
  • mysql 復(fù)制原理與實踐應(yīng)用詳解

    mysql 復(fù)制原理與實踐應(yīng)用詳解

    這篇文章主要介紹了mysql 復(fù)制原理與實踐應(yīng)用,結(jié)合實例形式詳細分析了MySQL數(shù)據(jù)庫復(fù)制功能的原理、操作技巧與相關(guān)注意事項,需要的朋友可以參考下
    2020-02-02
  • MySQL 全文檢索的使用示例

    MySQL 全文檢索的使用示例

    全文檢索是指計算機索引程序通過掃描文章中的每一個詞,對每一個詞建立一個索引,指明該詞在文章中出現(xiàn)的次數(shù)和位置,當用戶查詢時,檢索程序就根據(jù)事先建立的索引進行查找,并將查找的結(jié)果反饋給用戶的檢索方式。這個過程類似于通過字典中的檢索字表查字的過程。
    2021-06-06
  • MySQL?臨時表創(chuàng)建與使用詳細說明

    MySQL?臨時表創(chuàng)建與使用詳細說明

    MySQL臨時表是存儲在內(nèi)存或磁盤的臨時數(shù)據(jù)表,會話結(jié)束時自動銷毀,適合存儲中間計算結(jié)果或臨時數(shù)據(jù)集,其名稱以#開頭(如#TempTable),本文給大家介紹MySQL臨時表創(chuàng)建與使用詳細說明,感興趣的朋友跟隨小編一起看看吧
    2025-08-08
  • wampserver下mysql導(dǎo)入數(shù)據(jù)庫的步驟

    wampserver下mysql導(dǎo)入數(shù)據(jù)庫的步驟

    這篇文章主要介紹了wampserver下mysql導(dǎo)入數(shù)據(jù)庫的步驟,需要的朋友可以參考下
    2016-08-08
  • MySQL中order?by排序時數(shù)據(jù)存在null則排序在最前面的方法

    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問題

    這篇文章主要介紹了Mysql使用on update current_timestamp問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03

最新評論