utf8mb4編碼是utf8編碼的超集,兼容utf8,并且能存儲(chǔ)4字節(jié)的表情字符。
采用utf8mb4編碼的好處是:存儲(chǔ)與獲取數(shù)據(jù)的時(shí)候,不用再考慮表情字符的編碼與解碼問題。
更改數(shù)據(jù)庫(kù)的編碼為utf8mb4:
1. MySQL的版本
utf8mb4的最低mysql版本支持版本為5.5.3+,若不是,請(qǐng)升級(jí)到較新版本。
2. MySQL驅(qū)動(dòng)
5.1.34可用,最低不能低于5.1.13
SHOW VARIABLES WHERE Variable_name LIKE 'character_set_%' OR Variable_name LIKE 'collation%';

3.修改MySQL配置文件
修改mysql配置文件my.cnf
my.cnf一般在etc/mysql/my.cnf位置。找到后請(qǐng)?jiān)谝韵氯糠掷锾砑尤缦聝?nèi)容:
[client]
default-character-set = utf8mb4
[mysql]
default-character-set = utf8mb4
注目的地
[mysqld]
character-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init_connect='SET NAMES utf8mb4'
4. 重啟數(shù)據(jù)庫(kù),檢查變量
SHOW VARIABLES WHERE Variable_name LIKE 'character_set_%' OR Variable_name LIKE 'collation%';

collation_connection 、collation_database 、collation_server是什么沒關(guān)系。
但必須保證
系統(tǒng)變量 描述
character_set_client (客戶端來源數(shù)據(jù)使用的字符集)
character_set_connection (連接層字符集)
character_set_database (當(dāng)前選中數(shù)據(jù)庫(kù)的默認(rèn)字符集)
character_set_results (查詢結(jié)果字符集)
character_set_server (默認(rèn)的內(nèi)部操作字符集)
這幾個(gè)變量必須是utf8mb4。
5. 數(shù)據(jù)庫(kù)連接的配置
數(shù)據(jù)庫(kù)連接參數(shù)中:
characterEncoding=utf8會(huì)被自動(dòng)識(shí)別為utf8mb4,也可以不加這個(gè)參數(shù),會(huì)自動(dòng)檢測(cè)。
而autoReconnect=true是必須加上的。
6. 將數(shù)據(jù)庫(kù)和已經(jīng)建好的表也轉(zhuǎn)換成utf8mb4
更改數(shù)據(jù)庫(kù)編碼:ALTER DATABASE caitu99 CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
更改表編碼:ALTER TABLE TABLE_NAME CONVERT TO CHARACTER SET utf8mb4 COLLATEutf8mb4_general_ci;
如有必要,還可以更改列的編碼
總結(jié)
以上所述是小編給大家介紹的如何更改MySQL數(shù)據(jù)庫(kù)的編碼為utf8mb4,希望對(duì)大家有所幫助!
您可能感興趣的文章:- Spring Data Jpa Mysql使用utf8mb4編碼的示例代碼
- 設(shè)置mysql5.7編碼集為utf8mb4的方法
- mysql存儲(chǔ)emoji表情報(bào)錯(cuò)的處理方法【更改編碼為utf8mb4】
- MySQL 編碼utf8 與 utf8mb4 utf8mb4_unicode_ci 與 utf8mb4_general_ci