mysql utf8m64_让Mysql支持Emoji表情,解决[Err] 1366 - Incorrect string value: '\xF0\xA3\x84\x83'...

mysql insert内容包含表情或者unicode码时候,插入Mysql时失败了,报如下异常:

Java代码

java.sql.SQLException: Incorrect string value: '\xF0\x9F\x92\x94' for column 'name' at row 1at 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)

插入表情,或者类似下面sql文字情况,会发生这种问题

insert into aaa(id,name) values ('949','𣄃');

sql中的“𣄃”与通俗的"旗",字不同编码存储方式不同,复制到idea中就变样了,自动被解析成 "\uD84C\uDD03" 或者一块隐身文字。

解决问题,

1.设置表字段的编码为utf8mb4

ab0fd60d7646998d64cab3d097ae42b8.png

2.如果长久性的解决(我没验证过),可以想网上说的,修改mysql配置文件,数据库等所有编码为utf8m64

如修改my.cnf

[mysqld]

character-set-server=utf8mb4

[mysql]

default-character-set=utf8mb4

修改后重启Mysql

以root身份登录Mysql,修改环境变量,将character_set_client,character_set_connection,character_set_database,character_set_results,character_set_server 都修改成utf8mb4

3.我的解决方式(比较临时)

同一个connection下,设置一次set names utf8m64;

SET NAMES utf8mb4;

insert into aaa(id,name) values ('949','𣄃')

对应到java代码中也是一样

2a96a23c480ec0908d285ffeeab71b92.png

至此,OK了!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值