国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

mysql字符集相關總結

瀏覽:65日期:2023-10-05 10:33:58

這邊筆記主要記錄一下對mysql字符集相關知識的學習

字符集

一般我們使用如下語句創建一張表,創建表的時候指定了charset為utf8編碼。

CREATE TABLE `test` ( `c1` int UNSIGNED NOT NULL AUTO_INCREMENT, `c2` varchar(255), `c3` char(11), `c4` varchar(255), PRIMARY KEY (`c1`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;

但其實mysql也支持除了utf8之外的其他字符集,可以使用命令 show charset 查看當前mysql支持的所有字符集。

例如下圖就是我的mysql支持的所有字符集。

mysql字符集相關總結

可以從上圖中看到,第四列表示該字符集最大長度。我們建表時常用的 utf8 在mysql里面實際最大長度是 3 個字符。一般認知中utf8是用1~4個字符來表示具體的內容的,但mysql里面的 utf8 實際是 utf8mb3 的別名,正宗的的最大用4個字符表示的在mysql中是 utf8mb4 。

注意:

utf8mb4utf8mb4比較規則

在上面那張圖中,第三列 Default collation 就是這些字符集默認的比較規則。例如acsii字符集的默認比較規則是 ascii_general_ci ,utf8字符集的默認比較規則是 utf8_general_ci 。

其實每個字符集有很多種比較規則,例如我們看一下acsii字符集有哪些比較規則,如下圖所示

mysql> show collation like ’ascii%’;+------------------+---------+----+---------+----------+---------+| Collation | Charset | Id | Default | Compiled | Sortlen |+------------------+---------+----+---------+----------+---------+| ascii_general_ci | ascii | 11 | Yes | | 0 || ascii_bin | ascii | 65 | | | 0 |+------------------+---------+----+---------+----------+---------+

ascii_general_ci 表示是一種通用的比較,其中 _ci 表示是不區分大小寫(case insensitive)。(反之 _cs 就表示大小寫敏感)

ascii_bin 表示是二進制比較

再看一下utf8、utf8mb4字符集有哪些比較規則,如下圖所示

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 || utf8_icelandic_ci | utf8 | 193 | | Yes | 8 || utf8_latvian_ci | utf8 | 194 | | Yes | 8 || utf8_romanian_ci | utf8 | 195 | | Yes | 8 || utf8_slovenian_ci | utf8 | 196 | | Yes | 8 || utf8_polish_ci | utf8 | 197 | | Yes | 8 || utf8_estonian_ci | utf8 | 198 | | Yes | 8 || utf8_spanish_ci | utf8 | 199 | | Yes | 8 || utf8_swedish_ci | utf8 | 200 | | Yes | 8 || utf8_turkish_ci | utf8 | 201 | | Yes | 8 || utf8_czech_ci | utf8 | 202 | | Yes | 8 || utf8_danish_ci | utf8 | 203 | | Yes | 8 || utf8_lithuanian_ci | utf8 | 204 | | Yes | 8 || utf8_slovak_ci | utf8 | 205 | | Yes | 8 || utf8_spanish2_ci | utf8 | 206 | | Yes | 8 || utf8_roman_ci | utf8 | 207 | | Yes | 8 || utf8_persian_ci | utf8 | 208 | | Yes | 8 || utf8_esperanto_ci | utf8 | 209 | | Yes | 8 || utf8_hungarian_ci | utf8 | 210 | | Yes | 8 || utf8_sinhala_ci | utf8 | 211 | | Yes | 8 || utf8_german2_ci | utf8 | 212 | | Yes | 8 || utf8_croatian_ci | utf8 | 213 | | Yes | 8 || utf8_unicode_520_ci | utf8 | 214 | | Yes | 8 || utf8_vietnamese_ci | utf8 | 215 | | Yes | 8 || utf8_general_mysql500_ci | utf8 | 223 | | Yes | 1 || 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 || utf8mb4_latvian_ci | utf8mb4 | 226 | | Yes | 8 || utf8mb4_romanian_ci | utf8mb4 | 227 | | Yes | 8 || utf8mb4_slovenian_ci | utf8mb4 | 228 | | Yes | 8 || utf8mb4_polish_ci | utf8mb4 | 229 | | Yes | 8 || utf8mb4_estonian_ci | utf8mb4 | 230 | | Yes | 8 || utf8mb4_spanish_ci | utf8mb4 | 231 | | Yes | 8 || utf8mb4_swedish_ci | utf8mb4 | 232 | | Yes | 8 || utf8mb4_turkish_ci | utf8mb4 | 233 | | Yes | 8 || utf8mb4_czech_ci | utf8mb4 | 234 | | Yes | 8 || utf8mb4_danish_ci | utf8mb4 | 235 | | Yes | 8 || utf8mb4_lithuanian_ci | utf8mb4 | 236 | | Yes | 8 || utf8mb4_slovak_ci | utf8mb4 | 237 | | Yes | 8 || utf8mb4_spanish2_ci | utf8mb4 | 238 | | Yes | 8 || utf8mb4_roman_ci | utf8mb4 | 239 | | Yes | 8 || utf8mb4_persian_ci | utf8mb4 | 240 | | Yes | 8 || utf8mb4_esperanto_ci | utf8mb4 | 241 | | Yes | 8 || utf8mb4_hungarian_ci | utf8mb4 | 242 | | Yes | 8 || utf8mb4_sinhala_ci | utf8mb4 | 243 | | Yes | 8 || utf8mb4_german2_ci | utf8mb4 | 244 | | Yes | 8 || utf8mb4_croatian_ci | utf8mb4 | 245 | | Yes | 8 || utf8mb4_unicode_520_ci | utf8mb4 | 246 | | Yes | 8 || utf8mb4_vietnamese_ci | utf8mb4 | 247 | | Yes | 8 |+--------------------------+---------+-----+---------+----------+---------+

使用不同的比較規則對數據進行比較,結果可能是不一樣的。

字符集和比較規則是對應的,不管是只修改字符集還是只修改比較規則,另一方都會相應地自動變化。

四個級別的字符集和比較規則

上文提到了字符集和比較規則,實際上在mysql里面有不同級別的字符集和比較規則:

服務器級別 數據庫級別 表級別 列級別

服務器級別的字符集可以看參數 character_set_server ,服務器級別的比較規則可以看參數 collation_server

mysql> show variables like ’character_set_server’;+----------------------+-------+| Variable_name | Value |+----------------------+-------+| character_set_server | utf8 |+----------------------+-------+1 row in set (0.00 sec)mysql> show variables like ’collation_server’;+------------------+-----------------+| Variable_name | Value |+------------------+-----------------+| collation_server | utf8_general_ci |+------------------+-----------------+1 row in set (0.00 sec)

如果要查看數據庫級別的字符集和比較規則,那么可以先 use xxxdb 切換到具體的數據庫,然后執行 show variables like ’character_set_database’ 和 show variables like ’collation_database’ 來查看該數據庫的字符集和比較規則。

Database changedmysql> show variables like ’character_set_database’;+------------------------+-------+| Variable_name | Value |+------------------------+-------+| character_set_database | utf8 |+------------------------+-------+1 row in set (0.00 sec)mysql> show variables like ’collation_database’;+--------------------+-----------------+| Variable_name | Value |+--------------------+-----------------+| collation_database | utf8_general_ci |+--------------------+-----------------+1 row in set (0.00 sec)

如果要查看某個表的字符集和比較規則,或者表中的某個列的字符集和比較規則,那么可以使用 show create table xxxtb 來查看具體的建表語句,里面就有使用的字符集和比較規則。

如果創建數據庫的時候沒有指定字符集和比較規則,則會使用服務器級別的字符集和比較規則作為數據庫的字符集和比較規則。如果創建和修改表的語句中沒有指明字符集和比較規則,將使用該表所在數據庫的字符集和比較規則作為該表的字符集和比較規則

三個系統變量

mysql服務器可以對應多個客戶端,而這些客戶端的編碼方式可能不同,但存在數據庫里的數據的字符集是一定的,mysql就要針對不同的客戶端進行編碼轉換處理,然后返回結果給客戶端。

在mysql里面,有三個 SESSION級別 的系統變量,可以進行上述操作:

character_set_client : 服務器解碼客戶端請求時使用的字符集 character_set_connection : 服務器處理請求時會把請求字符串從character_set_client轉為character_set_connection character_set_results : 服務器向客戶端返回數據時使用的字符集

mysql服務器會為每個客戶端都維護一份session級別的這三個變量。

不過在實際生產環境中,為了避免麻煩,公司一般都會有規范規定客戶端默認都使用utf8字符集。

以上就是mysql字符集相關總結的詳細內容,更多關于mysql字符集的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 久久久久久久久久免免费精品 | 亚洲国产美女视频 | 中文字幕区 | 女初高中福利视频在线观看 | 久草在线看片 | 高清在线一区二区三区亚洲综合 | 欧美日韩a∨毛片一区 | 国产嫩草影院在线观看 | a级高清毛片 | 欧美日韩a∨毛片一区 | 亚洲国产精品久久日 | 国产高清视频免费在线观看 | 波多野结衣在线观看一区 | 狠狠干香蕉 | 一级黄片一级毛片 | 国产91丝袜在线播放九色 | 日韩欧美精品综合一区二区三区 | 91理论片 | 国产精品日韩欧美一区二区 | 美国三级在线观看 | 97影院理论在线观看 | 欧美最刺激好看的一级毛片 | 韩国porno xxxx| 一本伊大人香蕉高清在线观看 | 男人毛片| 国产精品三级一区二区 | 国产最新网站 | 国产在线精品一区二区三区不卡 | 免费精品久久久久久中文字幕 | 久久99一区 | 国产毛片久久精品 | 国产精品yjizz视频网一二区 | 玖玖精品视频在线 | 国产a级三级三级三级中国 国产a级特黄的片子视频 | 久久亚洲国产视频 | 欧美日韩高清性色生活片 | 免费看a级 | 初爱视频教程在线观看高清 | 国产伦码精品一区二区 | 亚洲成a人片在线观 | 性欧美成人依依影院 |