utf8mb4編碼是utf8編碼的超集,兼容utf8,并且能存儲4字節的表情字符。
采用utf8mb4編碼的好處是:存儲與獲取數據的時候,不用再考慮表情字符的編碼與解碼問題。
更改數據庫的編碼為utf8mb4:
1. MySQL的版本
utf8mb4的最低mysql版本支持版本為5.5.3+,若不是,請升級到較新版本。
2. MySQL驅動
5.1.34可用,最低不能低于5.1.13
1
|
SHOW VARIABLES WHERE Variable_name LIKE 'character_set_%' OR Variable_name LIKE 'collation%' ; |
3.修改MySQL配置文件
修改mysql配置文件my.cnf
my.cnf一般在etc/mysql/my.cnf位置。找到后請在以下三部分里添加如下內容:
1
2
3
4
|
[client] default - character - set = utf8mb4 [mysql] default - character - set = utf8mb4 |
注目的地
1
2
3
4
5
|
[mysqld] character - set -client-handshake = FALSE character - set -server = utf8mb4 collation-server = utf8mb4_unicode_ci init_connect= 'SET NAMES utf8mb4' |
4. 重啟數據庫,檢查變量
1
|
SHOW VARIABLES WHERE Variable_name LIKE 'character_set_%' OR Variable_name LIKE 'collation%' ; |
collation_connection 、collation_database 、collation_server是什么沒關系。
但必須保證
系統變量 描述
character_set_client (客戶端來源數據使用的字符集)
character_set_connection (連接層字符集)
character_set_database (當前選中數據庫的默認字符集)
character_set_results (查詢結果字符集)
character_set_server (默認的內部操作字符集)
這幾個變量必須是utf8mb4。
5. 數據庫連接的配置
數據庫連接參數中:
characterEncoding=utf8會被自動識別為utf8mb4,也可以不加這個參數,會自動檢測。
而autoReconnect=true是必須加上的。
6. 將數據庫和已經建好的表也轉換成utf8mb4
更改數據庫編碼:ALTER DATABASE caitu99 CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
更改表編碼:ALTER TABLE TABLE_NAME CONVERT TO CHARACTER SET utf8mb4 COLLATEutf8mb4_general_ci;
如有必要,還可以更改列的編碼
總結
以上所述是小編給大家介紹的如何更改MySQL數據庫的編碼為utf8mb4,希望對大家有所幫助!
原文鏈接:https://blog.csdn.net/eagle89/article/details/82148751