全部产品

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

KB: 41702

 · 

更新时间:2021-04-01 22:12

概述

本文主要介绍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实例:在RDS控制台将character_set_server参数设置为utf8mb4,且数据库和表的字符集也要设置为utf8mb4。

修改字符集

如果字符集不符合以上基本原则,请参见RDS MySQL字符集相关说明修改字符集。

说明:由utf8修改为utf8mb4字符集不会影响之后的数据质量,且已经存在的数据也不受影响,但是数据存储空间会有所增加。

适用于

  • 云数据库RDS MySQL版