设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 数据 创业者 手机
当前位置: 首页 > 站长学院 > MySql教程 > 正文

JDBC对Mysql utf8mb4字符集的处置

发布时间:2022-07-07 12:37 所属栏目:115 来源:互联网
导读:在开发微信开放平台, 接入微信公众号的数据时, 关于用户的nickname和文本消息是,大量出现emoji的文本信息, 超时了utf-8字符集的存储范围 在存储数据时, 出现部分特殊字符存储字符串失败. 服务端解决方案 查阅MySQL官方文档时,给出如下支持utf8转utf8mb4的官
  在开发微信开放平台, 接入微信公众号的数据时, 关于用户的nickname和文本消息是,大量出现emoji的文本信息, 超时了utf-8字符集的存储范围
 
  在存储数据时, 出现部分特殊字符存储字符串失败.
 
  服务端解决方案
  查阅MySQL官方文档时,给出如下支持utf8转utf8mb4的官方处理办法

  上述的步骤只是针对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 = FALSE
  character-set-server = utf8mb4
  collation-server = utf8mb4_unicode_ci
  重启服务MySQL服务
 
  问题到此解决。

(编辑:ASP站长网)

    网友评论
    推荐文章
      热点阅读