在微信開發過程當中,老是會遇到帶有emoji表情暱稱的微信用戶沒法自動登陸的問題。
後臺代碼拋出相似下面的異常信息。html
java.sql.SQLException: Incorrect string value: '\xF0\x9F\x92\x94' for colum n 'name' at row 1 at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1073) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3593) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3525) at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1986) at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2140) at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2620) at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1662) at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1581)
原來emoji表情是佔4個字節的,可是在MySQL中UTF-8字符只是佔3個字節,這就致使MySQL數據庫沒法保存emoji表情了。java
既然知道了緣由,那麼解決方法也就產生了。
只要讓MySQL的字符佔4個字節就成了。剛好MySQL5.5.3 之後的版本都有 utf8mb4 這種字符集,它每一個字符佔4個字節,知足保存emoji表情的須要。
如今目標是將MySQL數據庫有原來的字符集修改成 utf8mb4。mysql
ALTER DATABASE database_name CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci; ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; ALTER TABLE table_name CHANGE column_name VARCHAR(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
[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-connector-x.x.x.jar ,那麼mysql-connector的版本必須高於 5.1.13 ,不然不支持 utf8mb4。sql
參考這篇博客 mysql保存emoji表情(微信開發用戶暱稱..)數據庫