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

MySQL中utf8mb4排序規(guī)則示例

 更新時間:2021年07月29日 14:34:00   作者:TeyGao  
本文主要介紹了MySQL中utf8mb4排序規(guī)則,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

在MySQL中常見的utf8mb4排序規(guī)則有:

  • utf8mb4_0900_ai_ci
  • utf8mb4_unicode_ci
  • utf8mb4_general_ci

當設置表的默認字符集為utf8mb4字符集但未明確指定排序規(guī)則時:

  • 在MySQL 5.7版本中,默認排序規(guī)則為utf8mb4_general_ci。
  • 在MySQL 8.0版本中,默認排序規(guī)則為utf8mb4_0900_ai_ci。

由于utf8mb4_0900_ai_ci排序規(guī)則時MySQL 8.0引入的排序規(guī)則,因此將MySQL 8.0版本的表導入到MySQL 5.7或MySQL 5.6版本時,會存在字符集無法識別的問題。

[Err] 1273 - Unknown collation: 'utf8mb4_0900_ai_ci'

參數(shù)控制

在MySQL 5.6版本中,參數(shù)collation_server用于設置服務器級別的默認排序規(guī)則。

  • 如果服務啟動時未指定參數(shù)collation_database的值,則默認繼承參數(shù)collation_server的值。
  • 如果創(chuàng)建數(shù)據(jù)庫時未指定排序規(guī)則,則默認使用參數(shù)collation_database的值。

參數(shù)character_set_database和collation_database在MySQL 5.7版本中被遺棄并將在后續(xù)版本中移除。
MySQL新增參數(shù)default_collation_for_utf8mb4用于控制使用utf8mb4字符集時的默認排序規(guī)則,取值為utf8mb4_0900_ai_ci或utf8mb4_general_ci
參數(shù)default_collation_for_utf8mb4在下列條件中生效:

  • 使用SHOW COLLATION and SHOW CHARACTER SET 命令時。
  • 在創(chuàng)建庫或修改庫指定utf8mb4但未指定編碼規(guī)則時。
  • 在創(chuàng)建表或修改表指定utf8mb4但未指定編碼規(guī)則時。
  • 在增加列或修改列指定utf8mb4但未指定編碼規(guī)則時。
  • 其他使用utf8mb4但未指定編碼規(guī)則時。

utf8mb4_unicode_ci和utf8mb4_general_ci對比

1、準確性

  • utf8mb4_unicode_ci排序規(guī)則基于標準unicode進行排序和比較,能處理特殊的字符,能在各種語音中精確排序。
  • utf8mb4_general_ci排序規(guī)則沒有基于標準unicode,無法處理部分特殊字符。

2、性能

  • utf8mb4_general_ci排序規(guī)則在排序性能上相對較好
  • utf8mb4_unicode_ci排序規(guī)則為處理特殊字符實現(xiàn)復雜的排序算法,性能略差
  • 在大部分場景下,兩者沒有明顯的性能差異

補:MySQL--utf8mb4與等值查詢測試

測試腳本

## 刪除測試表
DROP TABLE IF EXISTS tb2001;
DROP TABLE IF EXISTS tb2002;
DROP TABLE IF EXISTS tb2003;

## 創(chuàng)建測試表
CREATE TABLE tb2001(
id INT AUTO_INCREMENT PRIMARY KEY,
c1 VARCHAR(100) COLLATE utf8mb4_unicode_ci,
c2 VARCHAR(100) COLLATE utf8mb4_bin
)ENGINE=INNODB DEFAULT CHARSET=utf8mb4 ;

CREATE TABLE tb2002(
id INT AUTO_INCREMENT PRIMARY KEY,
c1 VARCHAR(100) COLLATE utf8mb4_general_ci,
c2 VARCHAR(100) COLLATE utf8mb4_bin
)ENGINE=INNODB DEFAULT CHARSET=utf8mb4;

CREATE TABLE tb2003(
id INT AUTO_INCREMENT PRIMARY KEY,
c1 VARCHAR(100) COLLATE utf8mb4_0900_ai_ci,
c2 VARCHAR(100) COLLATE utf8mb4_bin
)ENGINE=INNODB DEFAULT CHARSET=utf8mb4;

## 插入測試數(shù)據(jù)
INSERT INTO tb2001(c1,c2)VALUES(0xF09F8D83,0xF09F8D83),(0xF09FA68A,0xF09FA68A),(0xF09F8CA0,0xF09F8CA0);
INSERT INTO tb2002(c1,c2)VALUES(0xF09F8D83,0xF09F8D83),(0xF09FA68A,0xF09FA68A),(0xF09F8CA0,0xF09F8CA0);
INSERT INTO tb2003(c1,c2)VALUES(0xF09F8D83,0xF09F8D83),(0xF09FA68A,0xF09FA68A),(0xF09F8CA0,0xF09F8CA0);

## 等值查詢測試
SELECT * FROM tb2001 WHERE c1=0xF09F8D83;
SELECT * FROM tb2002 WHERE c1=0xF09F8D83;
SELECT * FROM tb2003 WHERE c1=0xF09F8D83;

SELECT * FROM tb2001 WHERE c2=0xF09F8D83;
SELECT * FROM tb2002 WHERE c2=0xF09F8D83;
SELECT * FROM tb2003 WHERE c2=0xF09F8D83;

測試結果

mysql> SELECT * FROM tb2001 WHERE c1=0xF09F8D83;
+----+------+------+
| id | c1   | c2   |
+----+------+------+
|  1 | 🍃     | 🍃     |
|  2 | 🦊     | 🦊     |
|  3 | 🌠     | 🌠     |
+----+------+------+
3 rows in set (0.00 sec)

mysql> SELECT * FROM tb2002 WHERE c1=0xF09F8D83;
+----+------+------+
| id | c1   | c2   |
+----+------+------+
|  1 | 🍃     | 🍃     |
|  2 | 🦊     | 🦊     |
|  3 | 🌠     | 🌠     |
+----+------+------+
3 rows in set (0.01 sec)

mysql> SELECT * FROM tb2003 WHERE c1=0xF09F8D83;
+----+------+------+
| id | c1   | c2   |
+----+------+------+
|  1 | 🍃     | 🍃     |
+----+------+------+
1 row in set (0.00 sec)

mysql> 
mysql> SELECT * FROM tb2001 WHERE c2=0xF09F8D83;
+----+------+------+
| id | c1   | c2   |
+----+------+------+
|  1 | 🍃     | 🍃     |
+----+------+------+
1 row in set (0.00 sec)

mysql> SELECT * FROM tb2002 WHERE c2=0xF09F8D83;
+----+------+------+
| id | c1   | c2   |
+----+------+------+
|  1 | 🍃     | 🍃     |
+----+------+------+
1 row in set (0.00 sec)

mysql> SELECT * FROM tb2003 WHERE c2=0xF09F8D83;
+----+------+------+
| id | c1   | c2   |
+----+------+------+
|  1 | 🍃     | 🍃     |
+----+------+------+
1 row in set (0.00 sec)

測試總結

  • 使用utf8mb4字符集能存儲特殊字符如表情符號。
  • utf8mb4_unicode_ci和utf8mb4_general_ci排序規(guī)則無法"正確匹配"特殊字符。
  • utf8mb4_0900_ai_ci排序規(guī)則能"正確匹配"特殊字符,但僅適用MySQL 8.0版本。
  • utf8mb4_bin排序規(guī)則基于二級制方式匹配特殊字符,能"正確匹配"特殊字符,適用于MySQL各個版本。

到此這篇關于MySQL中utf8mb4排序規(guī)則示例的文章就介紹到這了,更多相關MySQL utf8mb4排序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Windows服務器下MySql數(shù)據(jù)庫單向主從備份詳細實現(xiàn)步驟分享

    Windows服務器下MySql數(shù)據(jù)庫單向主從備份詳細實現(xiàn)步驟分享

    將主服務器中的MySql數(shù)據(jù)庫同步到從服務器中,使得對主服務器的操作可以即時更新到從服務器,避免主服務器因環(huán)境或者網(wǎng)絡異常一時無法使用,達到備份效果,這篇文章整理的確實挺詳細的
    2012-05-05
  • MySQL 5.7.43下載安裝配置的超詳細教程

    MySQL 5.7.43下載安裝配置的超詳細教程

    這篇文章主要介紹了MySQL 5.7.43下載安裝配置的超詳細教程,本文通過實例圖文結合的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的幫助,需要的朋友可以參考下
    2023-09-09
  • MYSQL清空表和截斷表問題

    MYSQL清空表和截斷表問題

    這篇文章主要介紹了MYSQL清空表和截斷表問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • mysql中coalesce()的使用技巧小結

    mysql中coalesce()的使用技巧小結

    在mysql中,其實有不少方法和函數(shù)是很有用的,這次介紹一個叫coalesce的,拼寫十分麻煩,但其實作用是將返回傳入的參數(shù)中第一個非null的值,下面這篇文章主要給大家介紹了在mysql中coalesce()使用技巧的相關資料,需要的朋友可以參考下。
    2017-06-06
  • 定位和優(yōu)化mysql慢查詢的常見方法分享

    定位和優(yōu)化mysql慢查詢的常見方法分享

    MySQL中的慢查詢(Slow Query)指執(zhí)行時間超過指定閾值的查詢語句,默認閾值是long_query_time參數(shù)設置的秒值,MySQL有幾種常見的方法可以發(fā)現(xiàn)和獲取慢查詢,接下來小編將給大家詳細的介紹一下這些方法,需要的朋友可以參考下
    2023-08-08
  • MYSQL錯誤:Can’t open file: ‘×××.MYI’ (errno: 145)修復方法

    MYSQL錯誤:Can’t open file: ‘×××.MYI’ (errno: 14

    這個錯誤是典型的mysql表受損造成的,解決的辦法就是修復表,這個問題也是mysql經(jīng)常容易出現(xiàn)的,mysql表和索引損壞的幾率很大,但是修復也很方便
    2011-01-01
  • 詳解MySQL和Redis如何保證數(shù)據(jù)一致性

    詳解MySQL和Redis如何保證數(shù)據(jù)一致性

    MySQL與Redis都是常用的數(shù)據(jù)存儲和緩存系統(tǒng),為了提高應用程序的性能和可伸縮性,很多應用程序?qū)ySQL和Redis一起使用,其中MySQL作為主要的持久存儲,而Redis作為主要的緩存,那么本文就給大家介紹一下MySQL和Redis如何保證數(shù)據(jù)一致性,需要的朋友可以參考下
    2023-08-08
  • MySQL中因一個雙引號錯位引發(fā)的血案詳析

    MySQL中因一個雙引號錯位引發(fā)的血案詳析

    這篇文章主要給大家介紹了關于MySQL中因一個雙引號錯位引發(fā)的血案的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-11-11
  • 關于mysql中時間日期類型和字符串類型的選擇

    關于mysql中時間日期類型和字符串類型的選擇

    大家好,本篇文章主要講的是關于mysql中時間日期類型和字符串類型的選擇,感興趣的朋友趕快來看一看吧,希望對你有幫助
    2021-11-11
  • 允許遠程用戶訪問mysql服務sql語句

    允許遠程用戶訪問mysql服務sql語句

    本節(jié)主要介紹了如何允許遠程用戶訪問mysql服務,本例授權192.168.14.1 主機的cakephp用戶訪問cakephp數(shù)據(jù)庫
    2014-07-07

最新評論