电子商务平台网站建造,外贸网站建设方法,网站建设中 动画,网站开发与网页设计如何存Emoji表情
背景解决方案一#xff1a; 如果是自己搭建的数据库#xff0c;参考如下。 1#xff1a;先创建数据库#xff0c;utf8编码2#xff1a; 修改mysql 的配置文件 /etc/my.cnf 文件3#xff1a;然后把你的表和字段也要支持utf8md4编码4#xff1a;修改你连…如何存Emoji表情
背景解决方案一 如果是自己搭建的数据库参考如下。 1先创建数据库utf8编码2 修改mysql 的配置文件 /etc/my.cnf 文件3然后把你的表和字段也要支持utf8md4编码4修改你连接数据库的方式 二 如果你用的阿里云的数据库 1创建utf8mb4数据库2: 最后你连接数据库的方式如下 背景
我的项目技术栈 flask sqlalchemy mysql 在这样的架构下我想要mysql能存Emoji表情。
解决方案
如果想在数据库存emoji表情需要满足以下几种情况。 1: mysql 数据库要改成utf8md4编码格式因为这样才能存emoji四个字符的表情。 2: 客户端也要改成utf8md4的编码格式这里的客户端指的是后端工程师开发的服务器只是相对于数据库来说是是客户端。其实就是在连接mysql的时候指定一下以什么编码连接mysql数据库。
一 如果是自己搭建的数据库参考如下。
1先创建数据库utf8编码
CREATE DATABASE database name DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
1
2 修改mysql 的配置文件 /etc/my.cnf 文件 client default-character-set utf8mb4 mysqld character-set-serverutf8mb4 collation-serverutf8mb4_unicode_ci mysql default-character-set utf8mb4 3然后把你的表和字段也要支持utf8md4编码
略
4修改你连接数据库的方式
SQLALCHEMY_DATABASE_URI “mysql://账号:密码ip:port/数据库名?charsetutf8mb4”
主要在连接后面加上这个编码 ?charsetutf8mb4 二 如果你用的阿里云的数据库
1创建utf8mb4数据库 数据库里的表也要支持utf8md4 当我在阿里创建一个utf8mb4数据库, 然后ORM迁移后就已经数据库里的表就已经是utf8mb4编码了。 2: 最后你连接数据库的方式如下
SQLALCHEMY_DATABASE_URI “mysql://账号:密码ip:port/数据库名?charsetutf8mb4”
主要在连接后面加上这个编码 ?charsetutf8mb4 参考 https://www.jianshu.com/p/57d544acdc1f 参考阿里的描述 概述 本文主要介绍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版