[日常踩坑]--(3)MySQL存储emoji表情产生乱码

本文探讨了在MySQL中使用特定版本的mysql-connector-java时,存储emoji表情遇到的乱码问题。阐述了问题原因在于客户端和服务端编码不一致,并提供了两种解决方案:一是通过SQL语句设置字符集;二是升级mysql-connector-java版本。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Author:赵志乾
Date:2019-06-14
Declaration:All Right Reserved!!!

 

踩坑:

前提:mysql-connector-java版本为5.1.30,mysql版本为5.7.17。

场景:数据库指定字段类型为varchar,使用的字符集为utf8mb4,将emoji表情通过JDBC存储时产生乱码。

做法:jdbcUrl中使用characterEncoding=utf-8,并且没有做其他额外的数据库设置操作。

 

解决方案:

上述问题是因客户端和服务端使用的编码方式不一致导致的。可依据实际情况采用如下两种方案解决:

方案1:执行包含emoji表情的数据入库时,先执行字符集设置语句。如下:

set names utf8mb4

方案2:升级mysql-connector-java版本至5.1.47以上。在低于5.1.47版本时,jdbcUrl中设置的characterEncoding=utf-8对应mysql服务端的utf8,而从5.1.47开始,则对应到utf8mb4。如下:

 

知识背景:

mysql服务端的utf8编码占3个字节(即utf8mb3),而emoji表情占4个字节。故存储包含emoji表情的文本时要在服务端使用utf8mb4编码。

java中的utf8编码是可变长编码,其一个字符占用的长度可以为1、2、3或4个字节。
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我叫白小猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值