下面是我的处理方法:
要求:
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.最后修改数据库连接池的配置,增加一行:
<property name="connectionInitSqls" value="set names utf8mb4;"/>
5.检查下jdbc连接串的设置:
jdbc:mysql://localhost:3306/dbname?useUnicode=true&characterEncoding=utf8
这里要注意:有人建议删除useUnicode=true&characterEncoding=utf8,但好像我这里会发生保存数据时发生乱码的现象。