全部产品

RDS MySQL使用utf8mb4字符集存储emoji表情

概述

本文主要介绍RDS MySQL如何使用utf8mb4字符集存储emoji表情。

 

详细信息

阿里云提醒您:

  • 如果您对实例或数据有修改、变更等风险操作,务必注意实例的容灾、容错能力,确保数据安全。
  • 如果您对实例(包括但不限于ECS、RDS)等进行配置与数据修改,建议提前创建快照或开启RDS日志备份等功能。
  • 如果您在阿里云平台授权或者提交过登录账号、密码等安全信息,建议您及时修改。

 

基本原则

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

  • 客户端:客户端需要保证输出的字符串的字符集为utf8mb4。
  • 应用到RDS实例的连接:支持utf8mb4字符集。以常见的JDBC连接为例,需要使用MySQL Connector/J 5.1.13及以上的版本,JDBC的连接串中,建议不配置characterEncoding选项。
  • RDS实例配置:控制台设置参数character_set_server为utf8mb4、数据库的字符集为utf8mb4,以及表的字符集为utf8mb4。

RDS实例配置

RDS实例配置

RDS实例配置

 

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

对于JDBC连接串设置了characterEncoding为utf8,或者做了上述配置仍旧无法正常插入emoji数据的情况,建议在代码中指定连接的字符集为utf8mb4,示例代码如下。

String query = "set names utf8mb4";
stat.execute(query);

 

适用于

  • 云数据库 RDS MySQL 版