热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【MySQL】Java.sql.SQLExceptionIncorrectstringvalue:\xF0\x9F\x98\x8D\xE8\xBE...

1.背景因为用markdown写入的文件,现在要导入到mysql数据库,但是导入的时候报错如下。原因是该种字符串为Emoj表情内容,每个字符占用4个字节,在Mysql中默认最大

在这里插入图片描述


1.背景

因为用markdown写入的文件,现在要导入到mysql数据库,但是导入的时候报错如下。

原因是该种字符串为Emoj表情内容,每个字符占用4个字节,在Mysql中默认最大支持3个字节,超长了,所以报错了。


2.解决方法1

要用这种策略,如果MySql版本低于5.5.3,首先要进行版本升级,然后将对应的数据类型改为utf8mb4类型。如果使用的是Connector/J 连接数据库,需要在配置中把编码格式改为utf8mb4(set character_set_server=utf8mb4 in the connection config)

但是我没有测试通过


3.过滤字符

过滤掉Emoj表情相关字符,因为我这边不需要保留Emoj表情,不需要复原显示,所以我选择了简单的方式,过滤字符。

代码如下:

/*** 将emoji表情替换成空串* * @param source* @return 过滤后的字符串*/<

推荐阅读
author-avatar
风语飘散
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有