MySQL基礎(chǔ)學習之字符集的應用
字符集的查詢與修改
在MySQL 8.0
版本之前, 默認字符集是latin1
, 使用默認字符集的時候輸入中文會出現(xiàn)亂碼問題, 所以我們開發(fā)人員經(jīng)常會將MySQL
字符集的格式修改為utf8
解決亂碼問題, utf8字符集默認指向的是utf8mb3
格式編碼, 在MySQL 8.0
版本開始, 默認的字符集將改為了utf8mb4
, 有效的解決了中文亂碼問題
查看當前MySQL
數(shù)據(jù)庫使用的字符集
show variables like 'character%'; -- 或 show variables like '%char%';
MySQL 8.0版本查詢默認字符集
MySQL 5.7版本查詢默認字符集
對于MySQL 5.7
版本我們可以通過Navicat
等工具來對數(shù)據(jù)庫的默認字符集進行修改, 也可以通過修改MySQL
的配置文件my.cnf
來修改默認字符集
my.cnf
文件在Linux
系統(tǒng)下的地址是: /etc/my.cnf 在 [mysqld] 下新增 character_set_server=utf8
修改成功之后注意要重啟 MySQL, 使配置生效, 重啟命令systemctl restart mysqld.service
在上面字符集列表里面有幾個屬性可以了解一下:
character_set_client
服務器解碼請求時使用的字符集character_set_connection
服務器處理請求時會把請求字符串從character_set_client
轉(zhuǎn)為character_set_connection
character_set_results
服務器向客戶端返回數(shù)據(jù)時使用的字符集
字符集比較規(guī)則
utf8mb3和 utf8mb4
在日常操作中utf8
字符集表示一個字符需要 14個字節(jié), 但是我們常用的一些字符只需要使用 13個字節(jié), 而字符集表示使用一個字符的最大字節(jié)長度, 長度不同占用空間大小也不同, 所以在MySQL
中定義了utf8mb3
和utf8mb4
:
utf8mb3
1~3字節(jié)utf8mb4
1~4字節(jié)
在MySQL
中, utf8通常指的是 utf8mb4
查看當前MySQL
支持的字符集可輸入下列查詢:
show charset; -- 或 show character set;
我們可以看到查詢結(jié)果一共有四列, 分別是字符集名稱, 簡介, 該字符集默認排序規(guī)則, 使用該字符集最大字節(jié)數(shù)
Default collation
表示的是該字符集默認的比較規(guī)則, utf8_general_ci
是一種通用的比較規(guī)則,這里可以選擇比較規(guī)則主要作用于哪種語言 在我們使用Navicat
編輯數(shù)據(jù)庫的時候可以看到當前數(shù)據(jù)庫使用的字符集和排序規(guī)則
utf8_croatiian_ci
就是以羅克地亞語的規(guī)則比較,utf8_czech_ci
以捷克語的規(guī)則比較utf8_danish_ci
以丹麥語規(guī)則比較- ...
utf8_unicode_ci和 utf8_general_ci對中英文來說沒有區(qū)別 utf8_general_ci 校對速度快, 準確度較差 utf8_unicode_ci 準確度高, 但校對速度稍慢
一般來講使用utf8_general_ci
就夠了, 但是如果應用中使用到德語, 法語或者俄語, 一定要使用 utf8_unicode_ci, 因為 utf8_general_ci是一種比較老的標準 utf8_unicode_ci會更符合這些國家人們的習慣
比較規(guī)則后綴含義
后綴 | 英文釋義 | 描述 |
---|---|---|
_ai | accent insensitive | 不區(qū)分重音 |
_as | accent sensitive | 區(qū)分重音 |
_ci | case insensitive | 不區(qū)分大小寫 |
_cs | case sensitive | 區(qū)分大小寫 |
_bin | binary | 以二進制的方式比較 |
字符集常用SQL
-- 查看服務器的字符集和比較規(guī)則 show variables like '%_server'; -- 查看數(shù)據(jù)庫的字符集和比較規(guī)則 show variables like '%_database'; -- 查看具體數(shù)據(jù)庫的字符集 show create database 表名; -- 修改具體數(shù)據(jù)庫的字符集 alter database 表名 default character set 'utf8' collate 'utf8_general_ci';
修改數(shù)據(jù)庫的默認字符集和比較規(guī)則后, 原來已經(jīng)創(chuàng)建的表的字符集和比較規(guī)則并不會改變, 需要單獨的去更改
以上就是MySQL基礎(chǔ)學習之字符集的應用的詳細內(nèi)容,更多關(guān)于MySQL字符集的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
mysql修改數(shù)據(jù)庫默認路徑無法啟動問題的解決
這篇文章主要給大家介紹了關(guān)于mysql修改數(shù)據(jù)庫默認路徑無法啟動問題的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-11-11ARM64架構(gòu)下安裝mysql5.7.22的全過程
這篇文章主要介紹了ARM64架構(gòu)下安裝mysql5.7.22的全過程,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-07-07mysql8.0.11數(shù)據(jù)目錄遷移的實現(xiàn)
這篇文章主要介紹了mysql8.0.11數(shù)據(jù)目錄遷移的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-02-02MySQL查詢數(shù)據(jù)庫中某個庫、表、索引等所占空間的大小
MySQL是一個非常流行的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),它的查詢操作是非常強大和靈活的。查詢的效率不僅取決于表的大小,而且還取決于索引的大小,本文主要介紹了MySQL查詢數(shù)據(jù)庫中某個庫、表、索引等所占空間的大小,感興趣的可以了解一下2024-01-01