解决MySQL不能存储Emoji表情的问题

原因分析

在MySQL 5.5.3之前版本的数据库中,数据库的默认编码是utf8字符集,只支持1-3个字节的字符,也就是只能保存1到3个字节。但现在的emoji表情需要用4个字节才能保存,所以抛出异常。

解决方案

1、将数据表的编码格式设置成utf8mb4_general_ci

sql 复制代码
ALTER TABLE XXX CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

此时数据库已经可以支持emoji表情了

2、修改JDBC链接

sql 复制代码
修改前

jdbc.url=jdbc:mysql:/域名:端口/数据库?useUnicode=true&character_set_server=utf-8

修改后

jdbc.url=jdbc:mysql:/域名:端口/数据库?useUnicode=true&character_set_server=utf8mb4

最后修改druid数据源的配置,增加一行。

bash 复制代码
<property name="connectionInitSqls" value="set names utf8mb4;"/>
相关推荐
lixora5 分钟前
对指定Oracle datafile block hexdump 16进制转储
数据库
老华带你飞7 分钟前
学生宿舍管理|基于java + vue学生宿舍管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
正在走向自律10 分钟前
金仓数据库MongoDB兼容深度解析:多模融合架构与高性能实战
数据库·mongodb·架构·国产数据库·金仓数据库·信创改造
她说人狗殊途15 分钟前
NoSQL 数据库
数据库·nosql
码灵27 分钟前
SQL 关键字汇总
数据库·sql
星辰_mya1 小时前
Redis持久化
数据库·redis·缓存
橘子真甜~1 小时前
Reids命令原理与应用1 - Redis命令与原理
数据库·c++·redis·缓存
ZePingPingZe1 小时前
不使用Spring事务的管理—原生JDBC实现事务管理
java·数据库·spring
与遨游于天地1 小时前
了解Redis
数据库·redis·缓存
TG:@yunlaoda360 云老大1 小时前
如何了解华为云国际站代理商CDN主要有什么作用呢?
大数据·数据库·华为云