• ADADADADAD

    JDBC对Mysql utf8mb4字符集的处理[ mysql数据库 ]

    mysql数据库 时间:2024-12-25 09:54:55

    作者:文/会员上传

    简介:

    在开发微信开放平台, 接入微信公众号的数据时, 关于用户的nickname和文本消息是,大量出现emoji的文本信息, 超时了utf-8字符集的存储范围在存储数据时, 出现部分特殊字符存

    以下为本文的正文内容,内容仅供参考!本站为公益性网站,复制本文以及下载DOC文档全部免费。

    在开发微信开放平台, 接入微信公众号的数据时, 关于用户的nickname和文本消息是,大量出现emoji的文本信息, 超时了utf-8字符集的存储范围

    在存储数据时, 出现部分特殊字符存储字符串失败.

    服务端解决方案

    查阅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服务

    问题到此解决

    JDBC对Mysql utf8mb4字符集的处理.docx

    将本文的Word文档下载到电脑

    推荐度:

    下载
    热门标签: JavaJDBCmysql