MySQL支持emoji图标存储的反思

栏目: 数据库 · Mysql · 发布时间: 6年前

内容简介:解决方案:将Mysql的编码从utf8转换成utf8mb4。

MySQL支持emoji图标存储的反思

按网上的说法可以按以下方法配置:

解决方案:

Mysql 的编码从utf8转换成utf8mb4。

1. 修改my.ini在[mysqld]中增加如下内容

[client]

default-character-set=utf8mb4

[mysqld]

character-set-client-handshake = FALSE

character-set-server = utf8mb4

collation-server = utf8mb4_unicode_ci

init_connect=’SET NAMES utf8mb4'

[mysql]

default-character-set=utf8mb4

2. 在后台配置mysql连接参数中,不要加characterEncoding参数。 不加这个参数时,默认值就时autodetect。

3. 将已经建好的表也转换成utf8mb4

ALTER TABLE `daily_nursing_record` CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci; (将TABLE_NAME替换成你的表名)

4. 将需要使用emoji的字段设置类型为:(这个不一定需要)

ALTER TABLE `TABLE_NAME`MODIFY COLUMN `COLUMN_NAME` text CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

5.注意 show create table XXX;确保每个字段没有单独指定字符集

以上是网上的解决方法,但问题来了,如果字符集不是UTF8,会不会造成数据库乱码,虽然utf8mb4是UTF8的超集?

可不可以换个思路:

不直接将emoji图标存储到数据库,而是通过BASE64通过程序转换成字符串后再存入数据库,如果要取出来数据时,将BASE64字符再通过程序转换成emoji图标,这样是不是可以避免修改数据库字符集。因为修改数据库全局字符集是有很大的风险的。

经过与开发沟通,测试这种方法是可行的。

经过这件事,说明,做一件事其实有很多种方法,换个思路有些问题可以迎刃而解。

MySQL支持emoji图标存储的反思

MySQL支持emoji图标存储的反思


以上所述就是小编给大家介绍的《MySQL支持emoji图标存储的反思》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

八年级数学(华东师大版)-解题升级-解题快速反应一本通(新课标)

八年级数学(华东师大版)-解题升级-解题快速反应一本通(新课标)

孙丽敏等编 / 吉林教育出版社 / 2004-6 / 10.0

本书将与知识点、重点、难点和考点有关的典型题做全析全解,是具有解题题典性质的助学读物。但本书又优于解题题典,不仅展示解题过程,更详细地提供了解题思考过程和切入点的选择方法,教方法导引思路的功能更强。 学生要提高解题能力,必须具备两个条件:一是打好基础,二是能够运动所学知识分析问题和解决问题。本书用例题解析解说知识点、重点、难点和考点,同时提供解题思考过程,在打基础中激活能力,在解题实......一起来看看 《八年级数学(华东师大版)-解题升级-解题快速反应一本通(新课标)》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换