Mysql存儲微信Emoji表情問題

報錯如下:

insertTable 發生異常: (1366, "Incorrect string value: '\\xF0\\x9F\\x98\\x85\\xF0\\x9F...' for column 'content' at row 1")

上面錯誤意思是 mysql 數據庫中 content字段插入不正確的字符串值content字段是記錄微信評論帶表情,設計之初沒有考慮到微信呢稱中使用 Emoji 表情,導致寫入數據失敗。

utf8 爲什麼不支持 Emoji

utf8不支持emoji,是因爲emoji是用4個字節存儲的字符,而mysql的utf8只能存儲1-3個字節的字符。

解決方法

vi /etc/mysql/my.cnf,如下文件

!includedir /etc/mysql/conf.d/
!includedir /etc/mysql/mysql.conf.d/

在下面追加

[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'

重啓數據庫,檢查變量

mysql>  SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' OR Variable_name LIKE 'collation%';
+--------------------------+--------------------+
| Variable_name            | Value              |
+--------------------------+--------------------+
| character_set_client     | utf8mb4            |
| character_set_connection | utf8mb4            |
| character_set_database   | utf8mb4            |
| character_set_filesystem | binary             |
| character_set_results    | utf8mb4            |
| character_set_server     | utf8mb4            |
| character_set_system     | utf8               |
| collation_connection     | utf8mb4_unicode_ci |
| collation_database       | utf8mb4_unicode_ci |
| collation_server         | utf8mb4_unicode_ci |
+--------------------------+--------------------+
10 rows in set (0.00 sec)

必須保證下面幾個變量是 utf8mb4

系統變量               描述
character_set_client  客戶端來源數據使用的字符集
character_set_connection  連接層字符集
character_set_database 當前選中數據庫的默認字符集
character_set_results  查詢結果字符集
character_set_server  默認的內部操作字符集

將數據庫 和 已經建好的表也轉換成 utf8mb4

ALTER DATABASE `webMysqlDBTemp` CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci;

ALTER TABLE `task_comment_tb` CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; # 更改表編碼

ALTER TABLE `task_comment_tb` CHANGE `content` VARCHAR(1000) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;  # 更改列的編碼

查詢字符集編碼

show create database fangdai_CMS; # 查詢數據庫編碼
show create table t_member; # 查詢表編碼
show full columns from t_member; # 查詢所有表字段編碼

數據庫連接配置

添加 characterEncoding=utf8 會被自動識別爲 utf8mb4 ;autoReconnect=true 參數必須添加。

重啓數據庫

service mysql restart

就OK了

 

參考:

https://zhuanlan.zhihu.com/p/101325875

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章