牛骨文教育服务平台(让学习变的简单)
博文笔记

mysql对emoji特殊字符进行存储

创建时间:2016-12-05 投稿人: 浏览次数:2168

参考文章:微信nickname乱码(emoji)及mysql编码格式设置(utf8mb4)解决的过程


对数据库对应的字段要进行设置对应的utf8mb4字段属性:

ALTER TABLE 表名 MODIFY COLUMN 表字段 表属性 CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL;  

然后在数据库连接池的配置当中要设置字符集的设置


1.MySQL的版本不能太低,低于5.5.3的版本不支持utf8mb4编码。select version();
2.JDBC驱动版本不能太低,mysql connector版本高于5.1.13。
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.38</version>
</dependency>

3.将表中的对应字段,比如会员表的呢称字段,其字符集修改成utf8mb4。
4.最后修改druid数据源的配置,增加一行:


<property name="connectionInitSqls" value="set names utf8mb4;"/>

5.检查下jdbc连接串的设置:

jdbc:mysql://localhost:3306/dbname?useUnicode=true&characterEncoding=utf8

这里要注意:有人建议删除useUnicode=true&characterEncoding=utf8,但好像我这里会发生保存数据时发生乱码的现象。

声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。