按网上的说法可以按以下方法配置:
解决方案:
将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,会不会造成数据库乱码,虽然utf8mb4是UTF8的超集?
可不可以换个思路:
不直接将emoji图标存储到数据库,而是通过BASE64通过程序转换成字符串后再存入数据库,如果要取出来数据时,将BASE64字符再通过程序转换成emoji图标,这样是不是可以避免修改数据库字符集。因为修改数据库全局字符集是有很大的风险的。
经过与开发沟通,测试这种方法是可行的。
经过这件事,说明,做一件事其实有很多种方法,换个思路有些问题可以迎刃而解。