mysql对emoji特殊字符进行存储

参考文章:微信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>mysqlgroupId>
    <artifactId>mysql-connector-javaartifactId>
    <version>5.1.38version>
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,但好像我这里会发生保存数据时发生乱码的现象。

你可能感兴趣的:(后端,java)