数据中有emoji,导致插入不了数据库

数据中有emoji,导致插入不了数据库前言 前两天负责的系统,因为需要获取用户的昵称并进行入库,但是有个别用户的昵称中存在emoji表情,导致入库时报错。 报错内容: java.sql.SQLException: Incorrect st

数据中有emoji,导致插入不了数据库

前言

前两天负责的系统,因为需要获取用户的昵称并进行入库,但是有个别用户的昵称中存在emoji表情,导致入库时报错。

报错内容:
java.sql.SQLException: Incorrect string value: ‘xF0x9Fx92x94‘ for column

问题原因

Q:为什么我们设置表的的字符类型为utf8却不能存放emoji呢?

A:因为我们UTF-8编码可能是2或3或4个字节,但mysql中的utf8是3个字节,存放一个emoji是需要4个字节的,自然不够。

Mysql数据库在5.5.3之后开始支持utf8mb4字符集,所以mysql版本是5.5.3+的都可以设置让数据库存储Emoji表情

所以如果你的应用有移动端的,最好一开始设计数据库的时候就使用utf8mb4字符集

解决方案:

方案一: 过滤字符串中的emoji

方案二: 转译emoji后入库。获取时反转译成emoji使用

//转译emoji
URLEncoder.encode(含有emoji的数据, "UTF-8");
//反转译成emoji<br/>
URLDecoder.decode(经过转义的数据, "UTF-8");

另外再推荐一款emoji转义工具

注意点:emoji转译后可以入库。但当用户就是输入的内容本身就是【转译后的内容】

此时从库中反转译时就变成了emoji。这就造成跟用户输入不一致的情况

方案三: 修改数据库配置,实现可存储emoji

目前网上给的解决方案普遍都是:修改该字段或者该张表的编码方式为utf8mb4

但仅这么处理是并不起作用。

还需要执行SET NAMES utf8mb4; 将整个库的 character_set_client、character_set_connection、character_set_results等值修改为utf8mb4才会起作用

修改已经建立表的字符集alter table TABLE_NAME convert to character set utf8mb4 collate utf8mb4_bin;

注意点:新建数据库时可以进行初始化设置,但是已有的线上生产库进行此操作有风险,因此建议使用相关类库转义后进行存储和显示

使用下列SQL语句可以查看MySQL中character_set相关变量:
SHOW VARIABLES LIKE "%char%";

——The End——

感谢大家看到最后,文章持续更新!欢迎大家指出我的文章的不足之处,也欢迎大家关注、收藏+分享

如果这个办法对您有用,或者您希望持续关注,也可以扫描下方二维码或者在微信公众号中搜索【码路无涯】

数据中有emoji,导致插入不了数据库

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/5694.html

(0)
上一篇 2023-04-28
下一篇 2023-04-28

相关推荐

  • Python中的exp函数

    Python中的exp函数Python中的exp函数是一个数学函数,用于返回e的n次方的值。该函数常用于概率和统计学中的复利计算、指数增长和衰减等领域。

    2024-05-28
    68
  • 使用Pandas添加行

    使用Pandas添加行 Pandas是一个快速、灵活且易于使用的数据分析工具包,是Python数据分析中非常重要且广泛使用的一个库。本文将深入介绍在使用Pandas操作数据时,如何添加新行以及执行相关操作。

    2024-08-30
    22
  • Sql Server数据库远程连接访问设置「终于解决」

    Sql Server数据库远程连接访问设置「终于解决」步骤一:设置sql server数据库 1.以新建一个新用户名test作为远程连接登录名。在本地登录sql server数据库,安全性->右键用户名 2.点击根目录右键,选择属性 选择安全性 选

    2023-05-28
    150
  • Excel字符串截取函数「建议收藏」

    Excel字符串截取函数「建议收藏」引自:http://dl.iteye.com/upload/picture/pic/89262/8548ea0c-3d01-35c1-a49f-1166b20eb324.jpg一:函数理论知识学习  截取Excel字符串的部分字符,我们可以使用Mid、Left、Right等函数从长字符串内获取一部分字符。  ①LEFT函数:  LEFT(text,num_chars)  Te…

    2023-03-02
    144
  • mysql 可重复读 幻读_mysql如何实现可重复读

    mysql 可重复读 幻读_mysql如何实现可重复读1 mvcc 解决快照读幻读 2 GAP 锁解决 当前读幻读 (insert时 插入意向锁会等待GAP锁)

    2023-03-31
    154
  • Python中的concat函数使用方法

    Python中的concat函数使用方法Python作为一种高级编程语言,已经得到了广泛的应用。而作为Python中一个非常重要的函数,concat函数也被广泛应用于很多领域,如数据处理、文本处理等。该函数实现的是将两个或多个字符串连接起来形成一个新的字符串。本文主要介绍Python中的concat函数使用方法。

    2024-06-09
    53
  • Python NumPy数据类型转换:更改数据类型以满足特定需求

    Python NumPy数据类型转换:更改数据类型以满足特定需求Python NumPy是一个开源库,用于在Python中的数学计算与科学计算。作为一种数据处理和分析的工具,NumPy有俩个主要的对象:数组和矩阵。然而,像Python,NumPy也支持不同的数据类型,这些类型用于对数组的元素进行编码。这就是Python NumPy数据类型转换:更改数据类型以满足特定需求的重要性所在。

    2023-12-04
    123
  • [20191213]toad 12下BIND_AWARE提示无效.txt

    [20191213]toad 12下BIND_AWARE提示无效.txt[20191213]toad 12下BIND_AWARE提示无效.txt–//链接http://blog.itpub.net/267265/viewspace-2130781/的测试,发现当时测试的

    2022-12-26
    139

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注