我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql存储emoji表情步骤详解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mysql存储emoji表情步骤详解

Caused by: java.sql.SQLException: Incorrect string value: '\xF0\x9F\x94\xA5' for column Emoji表情存储到Mysql中时报错。

ios的表情(emoji表情),这种表情虽然是utf8编码,但是一个字符需要占用4个字节,而MySQL utf8编码只能存放3字节的字符。在MySQL 5.6中,可以设置编码为utf8mb4,这个字符集是utf8的超集。

mysql存储emoji表情步骤详解

1、修改MYSQL字符集

Mysql设置字符编码集为utf8mb4,对应的库、表、字段设置为utf8mb4,注意如果是已经存在的表utf8编码集修改为utf8mb4那么,库、表、字段都要设置并检查一次,如果只改库对应的表和字段都不会变化,改表也是如此。可能还需要重启数据库,如果改了配置的话。

character_set_server=utf8mb4

mysql存储emoji表情步骤详解

mysql存储emoji表情步骤详解

2、升级JDBC

低版本的JDBC会出现乱码,表情乱码,甚至中文乱码。

下面给出JDBC版本的一些对应情况,详情如下图JDBC版本支持EMOJI情况,网上找的图,我的5.1.6测试插入和显示中文及Emoji表情均正常。

mysql存储emoji表情步骤详解

3、继承服务器的配置jdbc:mysql://xxx.xxx.xxx.xxx:3306/dbwww58com_chrcsm?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true连接地址后的参数设定为UTF-8或可以被自动识别,如果不能可以试着去掉粗体部分,让连接自动识别服务器配置。具体情况与JDBC版本有关。继承服务器的配置jdbc:mysql://xxx.xxx.xxx.xxx:3306/dbwww58com_chrcsm?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true连接地址后的参数设定为UTF-8或可以被自动识别,如果不能可以试着去掉粗体部分,让连接自动识别服务器配置。具体情况与JDBC版本有关。

4、设置MYSQL的init_connect参数

设置后可以通过show variables like ‘init_connect';进行验证,如下图2 init_connect参数查询,所示:

mysql存储emoji表情步骤详解

5、代码中设置编码集或许是因为JDBC版本的原因,我是采用的这种方式,插入和查询均能正常进行。connection.prepareStatement(“set names utf8mb4”).executeQuery();然后再通过connection.prepareStatement,这样的方式进行插入。代码中设置编码集或许是因为JDBC版本的原因,我是采用的这种方式,插入和查询均能正常进行。connection.prepareStatement(“set names utf8mb4”).executeQuery();然后再通过connection.prepareStatement,这样的方式进行插入。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql存储emoji表情步骤详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySql存储表情报错的排查解决

目录前言 问题排查解决mysql变量配置扩展补充总结前言 操作系统:linux数据库版本: 8.0.27查看版本命令:mysql -uroot -p 登录成功后就可以看到问题个人博客markdown插入标签后报以下错误报错信息:In
2022-07-08

获取包含emoji表情的微信昵称存储至mysql数据库报错的解决办法

将相关字段字符集改为utf8mb4 且php代码中关于数据库连接的字符集设置为utf8mb4 [ "charset" => "utf8mb4", "collation" => "utf8mb4_general_ci",
2017-11-04

windows8存储空间设置步骤详细图解

“存储空间”的新功能将利用一个物理存储设施组成数据池。这个数据池将使用 SATA、USB 和 SAS 硬盘创建,并且能够使用额外的硬件扩展。 这些称作“空间”的虚拟硬盘能够把 4TB 存储空间
2022-06-04

MySQL之存储过程按月创建表的方法步骤

具体不多说,直接上代码。欢迎一起交流和学习。创建一个按月创建表的存储过程,SQL语句如下:DELIMITER // DROP PROCEDURE IF EXISTS create_table_by_month // CREATE PROC
2022-05-11

mysql数据库单表最大存储依据详解

目录引言数据库单表行数最大多大?索引的结构页的结构从页到索引B+树承载的记录数量x怎么算y的计算行总数计算行数超一亿就慢了吗?B树承载的记录数量总结引言故事从好多年前说起。想必大家也听说过数据库单表建议最大2kw条数据这个说法。如果超过
2022-07-18

编程热搜

目录