mysql 插入数据时,出现"\xF0\x5F\x6F\x70"问题

背景

下午在做测试的时候,测试环境突然报插入数据库 Incorrect string value: ‘\xF0\x9F\x98\x82\xF0\x9F…’ for column ‘question’ at row 1这种异常,经过多方查找是因为编码的问题。
一般设置为“utf-8”,这对于汉字来说足够了,在mysql中utf8占3个字节,但是对于移动端的特殊表情符号来说,三个字节是不够的,他需要四个字节。这个时候我们使用utf8就会出现‘\xF0\x9F\x8F\x80’的问题。

解决方法

1、需要改数据库表的编码格式,将至修改为utf8mb4. mysql版本5.5.3之前支持utf8三个字节,5.5.3之后支持utf8mb4四个字节。mysql -V 查看版本,如果版本过低,先升级。
2、服务器连接数据库的url中不要有characterEncoding=utf-8。例如:

url=jdbc:mysql://127.0.0.1:3306/xxx

发布了143 篇原创文章 · 获赞 13 · 访问量 2万+

猜你喜欢

转载自blog.csdn.net/TreeShu321/article/details/103206916
今日推荐