mysql中插入emoji表情失敗的原因與解決
失敗場景
用戶昵稱中存在emoji表情,調用jdbc往mysql數據庫插入的時候拋出異常 java.sql.SQLException: Incorrect string value: '\xF0\x9F\x90\x9B'
失敗原因
mysql的utf8編碼的一個字符最多3個字節(jié),但是一個emoji表情為4個字節(jié),所以utf8不支持存儲emoji表情。但是utf8的超集utf8mb4一個字符最多能有4字節(jié),所以能支持emoji表情的存儲。
下面話不多說了,來一起看看詳細的介紹吧
解決方案
一. 修改database、table、column字符集
修改database字符集
ALTER DATABASE 數據庫名 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci;
修改table字符集
ALTER TABLE 表名 CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
修改column字符集
ALTER TABLE 表名 CHANGE 字段名 字段名 該字段原來的數據類型 CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
以上三種可以根據自己的實際情況來選擇修改;
二. 查看mysql配置變量
SHOW VARIABLES WHERE Variable_name LIKE 'character_set_%' OR Variable_name LIKE 'collation%';

注意 character_set_server 這個變量的值是否等于 utf8mb4 ,如果不是那么看第三步。
三. 修改mysql配置文件
這邊 mysql 是安裝在 centos 下的,配置文件名稱為 my.cnf ,路徑按照自己安裝的目錄來。
vim /etc/my.cnf /etc/mysql/my.cnf

my.cnf
找到 character_set_server ,將其值設置為 utf8mb4 ,保存退出;試著重新 insert 看是否報錯;如果報錯可能需要重啟下 mysql 服務
service mysqld restart
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
MYSQL5.6.33數據庫主從(Master/Slave)同步安裝與配置詳解(Master-Linux Slave-w
這篇文章主要為大家詳細介紹了MYSQL5.6.33數據庫主從(Master/Slave)同步安裝與配置,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06
SQLyog錯誤號碼MySQL?plugin?caching_sha2_password?could?not?
這篇文章主要介紹了SQLyog錯誤號碼?plugin?caching_sha2_password?could?not?be?loaded的解決方法,需要的朋友可以參考下2023-06-06
Mysql啟動報錯Error1045(28000)的原因分析及解決
這篇文章主要介紹了Mysql啟動報錯Error1045(28000)的原因分析及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2025-04-04
MySQL JOIN關聯(lián)查詢的原理及優(yōu)化
這篇文章主要介紹了MySQL JOIN關聯(lián)查詢的原理及優(yōu)化,文章圍繞主題展開詳細的內介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-08-08
SQL HAVING子句在GROUP BY中的條件篩選靈活運用
這篇文章主要為大家介紹了SQL HAVING子句在GROUP BY中的條件篩選靈活運用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-11-11

