使用jdbc来处理MySQL的utf8mb4字符集(转) - 女儿控老徐的专栏 - CSDN博客

原文链接地址:

http://blog.51cto.com/11931236/2057929

服务端解决方案

查阅MySQL官方文档时,给出如下支持utf8转utf8mb4的官方处理办法

https://dev.mysql.com/doc/refman/5.7/en/charset-unicode-conversion.html

上述的步骤只是针对server端的配置.

对于客户端需要额外特殊的处理

因为我目前的项目, 使用的是JAVA编写, 使用JDBC连接操作数据库, 如下针对的JDBC操作的解决方案

JDBC的URL之前的配置方式

String url = "jdbc:mysql://HOST:PORT/DATABASE?useUnicode=true&characterEncoding=UTF-8";

在连接配置中,声明UTF-8的字符编码,在目前的存储需求上来讲,在存储emoji字符串时会报错. 就算服务端的数据库设置了utf8mb4字符集类型

客户端修改成如下配置

String url = "jdbc:mysql://HOST:PORT/DATABASE?useUnicode=true&characterEncoding=utf8mb4";

客户端连接时报错,不支持该字符集

上述问题的解决方案

连接配置改成

String url = "jdbc:mysql://HOST:PORT/DATABASE";

同时数据库配置文件my.cnf 进行相应的修改

[client]default-character-set = utf8mb4[mysql]default-character-set = utf8mb4[mysqld]character-set-client-handshake = FALSEcharacter-set-server = utf8mb4collation-server = utf8mb4_unicode_ci

重启服务MySQL服务

问题到此解决


Original url: Access
Created at: 2019-05-27 17:09:53
Category: default
Tags: none

请先后发表评论
  • 最新评论
  • 总共0条评论