让Java后台MySQL数据库能够支持emoji表情的方法

发布时间 - 2026-01-10 23:25:52    点击率:

前言

公司最近在开发中遇到一个问题,在弄帖子的发布与回复问题,然后再iOS端和Android端添加表情的时候都会出错

Caused by: java.sql.SQLException: Incorrect string value: '\xF6\x9D\x98\x84' for column 'comment' at row 1

提示表情有问题,然后赶紧查资料。

首先数据库编码为UTF-8,字段content设置为text(CHARSET=utf8 COLLATE=utf8_unicode_ci)用于存储帖子内容信息,现在上线新功能存储emoji表情,插入emoji表情就会报出上述错误,UTF-8编码有可能是两个、三个、四个字节。Emoji表情是4个字节,而Mysql的utf8编码最多3个字节,所以数据插不进去。utf8mb4兼容utf8,且比utf8能表示更多的字符,所以要设置数据库的编码为utf8mb4。

数据库编码从utf8设置为utf8mb4

1、修改my.cnf

[client]
default-character-set=utf8mb4
 
[mysql]
default-character-set=utf8mb4
 
[mysqld]
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init_connect = 'SET NAMES utf8mb4'
character-set-client-handshake = false

2、对数据库相关的表进行字符集修改

将数据库转换为utf8mb4

ALTER DATABASE post CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
 
ALTER TABLE `post_article` CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
 
ALTER TABLE `post_article` MODIFY COLUMN `content` text CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

3、重启数据库

sudo /etc/init.d/mysql restart

4、检查数据库的字符集是否是utf8mb4

SHOW VARIABLES WHERE Variable_name LIKE 'character%' OR Variable_name LIKE 'collation%';

5、java 设置

设置Java的数据库连接,将characterEncoding去掉,然后保证mysql connector版本高于5.1.13,就OK了

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。


# mysql支持emoji表情  # emoji表情  # 数据库  # mysql保存emoji表情  # mysql存储emoji表情步骤详解  # mysql中插入emoji表情失败的原因与解决  # MySQL无法存储emoji表情解决方案分析  # mysql存储emoji表情报错的处理方法【更改编码为utf8mb4】  # MySQL无法存储Emoji表情问题的解决方法分析  # MySQL插入emoji表情失败问题的解决方法  # 使MySQL能够存储emoji表情字符的设置教程  # MySQL如何插入Emoji表情  # 设置为  # 就会  # 有可能  # 最多  # 然后再  # 一个问题  # 这篇文章  # 谢谢大家  # 重启  # 转换为  # 不进去  # 有疑问  # comment  # UTF  # row  # column  # x9D  # content  # COLLATE  # emoji 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】  网易LOFTER官网链接 老福特网页版登录地址  Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】  如何基于云服务器快速搭建个人网站?  Laravel如何理解并使用服务容器(Service Container)_Laravel依赖注入与容器绑定说明  php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】  网站制作报价单模板图片,小松挖机官方网站报价?  Laravel如何创建和注册中间件_Laravel中间件编写与应用流程  专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  Laravel怎么连接多个数据库_Laravel多数据库连接配置  Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】  如何在浏览器中启用Flash_2025年继续使用Flash Player的方法【过时】  七夕网站制作视频,七夕大促活动怎么报名?  在线制作视频的网站有哪些,电脑如何制作视频短片?  Laravel 419 page expired怎么解决_Laravel CSRF令牌过期处理  网站制作壁纸教程视频,电脑壁纸网站?  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?  Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤  如何用JavaScript实现文本编辑器_光标和选区怎么处理  微信小程序制作网站有哪些,微信小程序需要做网站吗?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  Laravel怎么多语言本地化设置_Laravel语言包翻译与Locale动态切换【手册】  昵图网官网入口 昵图网素材平台官方入口  Laravel如何创建自定义Artisan命令?(代码示例)  大同网页,大同瑞慈医院官网?  如何用AI帮你把自己的生活经历写成一个有趣的故事?  Python自然语言搜索引擎项目教程_倒排索引查询优化案例  Laravel如何实现数据导出到PDF_Laravel使用snappy生成网页快照PDF【方案】  Android GridView 滑动条设置一直显示状态(推荐)  浅述节点的创建及常见功能的实现  如何快速登录WAP自助建站平台?  利用 Google AI 进行 YouTube 视频 SEO 描述优化  如何生成腾讯云建站专用兑换码?  Laravel如何生成URL和重定向?(路由助手函数)  Gemini手机端怎么发图片_Gemini手机端发图方法【步骤】  Win11怎么关闭专注助手 Win11关闭免打扰模式设置【操作】  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  如何快速搭建高效可靠的建站解决方案?  大学网站设计制作软件有哪些,如何将网站制作成自己app?  如何在Windows环境下新建FTP站点并设置权限?  JS去除重复并统计数量的实现方法  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  创业网站制作流程,创业网站可靠吗?  Laravel Blade组件怎么用_Laravel可复用视图组件的创建与使用  Laravel怎么创建控制器Controller_Laravel路由绑定与控制器逻辑编写【指南】  Laravel如何使用Gate和Policy进行权限控制_Laravel权限判定与策略规则配置  Laravel如何记录日志_Laravel Logging系统配置与自定义日志通道  Laravel如何处理CORS跨域问题_Laravel项目CORS配置与解决方案  魔方云NAT建站如何实现端口转发?