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 COLLATEutf8mb4_general_ci;
(将TABLE_NAME替换成你的表名)               
4.
将需要使用emoji的字段设置类型为:(这个不一定需要)
ALTER TABLE `TABLE_NAME`MODIFY COLUMN `COLUMN_NAME` text CHARACTER SET utf8mb4COLLATE utf8mb4_general_ci;
5.
注意 showcreate table XXX;确保每个字段没有单独指定字符集

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

可不可以换个思路:

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

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

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

 


分割线
感谢打赏
江西数库信息技术有限公司
YWSOS.COM 平台代运维解决方案
 评论
 发表评论
姓   名:

Powered by AKCMS