阿里云RDS for MySQL使用utf8mb4编码存储Emoji表情

本文讲述了如何修复公司APP项目中Emoji表情输入导致的MySQL存取错误,涉及数据库编码升级、参数调整、数据迁移和连接设置的步骤,确保兼容utf8mb4并解决索引限制问题。

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

问题描述

公司的APP项目中输入Emoji表情和火星文等特殊字符时,后台接口存入数据库报错,错误信息如下:

Caused by: java.sql.SQLException: Incorrect string value: '\xF0\x9F\x98\x97\xF0\x9F...' for column 'CONTENT' at row 1

问题分析

  • 问题是移动端的emoji表情为四个字节,而MySQL的utf8编码方式的数据为三个字节。将MySQL的utf8编码改为utf8mb4编码方式就可以进行存储了。
  • 这里需要注意是MySQL必须是5.5.3以上版本,我们使用的是5.6版本所以没有问题可以改。

解决过程

本文主要参考了阿里云官方帮助文档《RDS MySQL使用utf8mb4字符集存储emoji表情》

1、查看数据库是否支持utf8mb4

在数据库client终端查看数据库是否支持utf8mb4编码方式

SHOW CHAR SET WHERE Charset LIKE "%utf8%";

在这里插入图片描述

2、修改参数

在RDS控制台-参数配置功能中修改character_set_server参数为utf

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值