数据库您现在的位置是:首页 > 博客日志 > 数据库

MySQL不支持emoji表情的解决方法

<a href='mailto:'>微wx笑</a>的头像微wx笑2019-08-30 17:02:57数据库人已围观关键字:mysql,emoji

简介MySQL不支持emoji表情的解决方法前段时间做项目遇到APP评论中有 emoji 表情符号,结果导致插入 MySQL 数据库失败,时隔好久了,现在整理一下。一、基本原则如果要实现存储 emoji

MySQL不支持emoji表情的解决方法rBP编程技术_踩坑日志_进阶指南 - 无知人生


rBP编程技术_踩坑日志_进阶指南 - 无知人生

前段时间做项目遇到APP评论中有 emoji 表情符号,结果导致插入 MySQL 数据库失败,时隔好久了,现在整理一下。rBP编程技术_踩坑日志_进阶指南 - 无知人生

一、基本原则

如果要实现存储 emoji 表情到 MySQL 实例,需要应用客户端、到 MySQL 实例的连接、MySQL 实例内部 3 个方面统一使用或者支持 utf8mb4 字符集。

注:关于 utf8mb4 字符集,请参考 utf8mb4 字符集(4字节 UTF-8 Unicode 编码)
rBP编程技术_踩坑日志_进阶指南 - 无知人生

二、三个条件的说明

1、应用客户端

客户端需要保证输出的字符串的字符集为 utf8mb4。
rBP编程技术_踩坑日志_进阶指南 - 无知人生

注:utf8mb4只是MySQL中的概念,因为MySQL的UTF-8并不是真正意义上的UTF-8,我们的应用中只要使用UTF-8就可以了。rBP编程技术_踩坑日志_进阶指南 - 无知人生

2、应用到 RDS MySQL 实例的连接

以常见的 JDBC 连接为例:
对于 JDBC 连接,需要使用 MySQL Connector/J 5.1.13(含)以上的版本。
JDBC 的连接串中,不配置 characterEncoding 选项。连接器会自动匹配识别字符集。
注:关于 MySQL Connector/J 5.1.13,请参考 MySQL 官方 Release Notes
比如
rBP编程技术_踩坑日志_进阶指南 - 无知人生


rBP编程技术_踩坑日志_进阶指南 - 无知人生

url=jdbc:mysql://localhost:3306/db_name?useUnicode=true&zeroDateTimeBehavior=convertToNull

3、MySQL 实例配置

3.1、修改my.cnf配置文件

注意:不同的系统配置文件名及位置可能不同;rBP编程技术_踩坑日志_进阶指南 - 无知人生

Windows下一般为:my.inirBP编程技术_踩坑日志_进阶指南 - 无知人生

CentOS下为:/usr/my.cnfrBP编程技术_踩坑日志_进阶指南 - 无知人生

macOS下刚安装完的路径可能是:/usr/local/mysql/my.cnf,但不起作用,需要放到:/etc/my.cnf 才会起作用rBP编程技术_踩坑日志_进阶指南 - 无知人生


rBP编程技术_踩坑日志_进阶指南 - 无知人生

这里使用VI来修改,输入命令:vi /usr/my.cnf 回车;打开文件后按“i”键进入编辑状态;
添加以下配置项,最主要的是“[mysqld]”下面的“character_set_server=utf8mb4”rBP编程技术_踩坑日志_进阶指南 - 无知人生

[client]
default-character-set = utf8mb4
[mysql]
default-character-set = utf8mb4
[mysqld]
character-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init_connect='SET NAMES utf8mb4'

按Esc键进入命令模式,输入“:wq”回车(保存并退出)。如果文件是只读的,输入“:wq!”回车(保存并退出)。rBP编程技术_踩坑日志_进阶指南 - 无知人生

注意:必须重新启动 MySQL 实例;
rBP编程技术_踩坑日志_进阶指南 - 无知人生

3.2、设置库的字符集为 utf8mb4

可以使用工具来设置数据库属性:rBP编程技术_踩坑日志_进阶指南 - 无知人生

rBP编程技术_踩坑日志_进阶指南 - 无知人生

3.3、设置表的字符集为 utf8mb4

rBP编程技术_踩坑日志_进阶指南 - 无知人生

create table emoji_table (id int auto_increment primary key,content varchar(255))  default charset utf8mb4;

如果数据表已经存在,可以使用Navicat for mysql或phpadmin等工具修改
rBP编程技术_踩坑日志_进阶指南 - 无知人生

image.pngrBP编程技术_踩坑日志_进阶指南 - 无知人生

3.4、设置字段的字符集为 utf8mb4


rBP编程技术_踩坑日志_进阶指南 - 无知人生

三、通过 set names 命令设置会话字符集

对于 JDBC 连接串设置了 characterEncoding 为 utf8 或者做了上述配置仍旧无法正常插入 emoji 数据的情况,建议在代码中指定连接的字符集为 utf8mb4,样例代码如下:
rBP编程技术_踩坑日志_进阶指南 - 无知人生


rBP编程技术_踩坑日志_进阶指南 - 无知人生

rBP编程技术_踩坑日志_进阶指南 - 无知人生

String sqlCharset = "set names utf8mb4"Statement statment = conn.createStatement();resultSet = statment.executeQuery(sqlCharset);

注: set names utf8mb4; 命令会将 character_set_client、character_set_connection、character_set_results 3个会话字符集相关变量均设置为 utf8mb4,以保证写入或者读出的数据使用 utf8mb4 字符集进行解释。

rBP编程技术_踩坑日志_进阶指南 - 无知人生


rBP编程技术_踩坑日志_进阶指南 - 无知人生

相关阅读rBP编程技术_踩坑日志_进阶指南 - 无知人生

 Incorrect string value: '\xF0\x9F\x98\xB8' for column 'smalltext' at row 1 rBP编程技术_踩坑日志_进阶指南 - 无知人生

utf8mb4 字符集(4字节 UTF-8 Unicode 编码)
rBP编程技术_踩坑日志_进阶指南 - 无知人生

CentOS下安装MySQL,Windows下使用Navicat for MySql连接
rBP编程技术_踩坑日志_进阶指南 - 无知人生

MySQL学习(二)图形界面管理工具Navicat for MySQL安装和使用
rBP编程技术_踩坑日志_进阶指南 - 无知人生

本文由 微wx笑 创作,采用 CC BY-NC 4.0 许可协议。 非商业性使用可自由转载、引用、甚至修改,但需署名作者且注明出处。

很赞哦! () 有话说 ()

点击排行

站点信息

  • 建站时间:2018-10-24
  • 服务期限阿里云ECS 2027年到期
  • 主题模板:基于《今夕何夕》修改
  • 文章统计:179篇
  • 文章评论:14条
  • 文章阅读:1338次
  • 文章点赞:650次
  • 微信公众号:扫描二维码,关注我们