1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > mysql 存微信表情 MySQL保存 emoji 表情(微信昵称表情)

mysql 存微信表情 MySQL保存 emoji 表情(微信昵称表情)

时间:2020-11-22 19:57:05

相关推荐

mysql 存微信表情 MySQL保存 emoji 表情(微信昵称表情)

问题分析

在微信开发过程当中,老是会遇到带有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

1. 修改数据库、表、列的字符集

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;

2. 修改MySQL配置文件 f(windows下是 my.ini)

[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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。