返回顶部
首页 > 资讯 > 后端开发 > Python >关于Java中使用jdbc连接数据库中文出现乱码的问题
  • 245
分享到

关于Java中使用jdbc连接数据库中文出现乱码的问题

jdbc连接jdbc连接数据库数据库中文乱码 2023-05-15 20:05:42 245人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

目录一、使用jdbc连接数据库,插入数据库时,数据里的数据显示乱码,为 " ??? "二、为什么配置了character_set_server = utf8,jd

一、使用jdbc连接数据库,插入数据库时,数据里的数据显示乱码,为 " ??? "

两种解决方案:

1、修改服务端的mysql配置文件,编辑my.cnf文件,在[mysqld]下添加一行character_set_server = utf8,然后重启mysql服务

2、使用jdbc连接时,指定正确的编码,jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=utf8

二、为什么配置了character_set_server = utf8,jdbc连接时就可以不指定编码

查阅官方文档,jdbc在连接数据库时,会先查询服务端的character_set_server值,再确定连接时使用的编码。要想覆盖客户端的自动检测编码功能,可以使用characterEncoding属性

文档地址:https://dev.mysql.com/doc/connector-j/8.0/en/connector-j-reference-charsets.html

三、MYSQL的字符处理机制是怎样的,为什么jdbc不指定编码或者服务端不设置character_set_server=utf8会导致乱码

先查看下MYSQL的字符集

解释下这几个参数:

character_set_client:客户端来源数据使用的字符集
character_set_connection:连接层字符集
character_set_database:当前选中数据库的默认字符集
character_set_filesystem:把os上文件名转化成此字符集,默认binary是不做任何转换的
character_set_results:查询结果字符集
character_set_server:默认的内部操作字符集
character_set_system:系统元数据字符集
character_sets_dir:字符集的路径

修改服务端的mysql配置文件,编辑my.cnf文件,在[mysqld]下添加一行character_set_server = utf8,然后重启mysql服务,再去查询字符集:

然后了解下字符集转换流程:

插入数据:

服务端将数据由客户端(character_set_client)字符集转成character_set_connection,然后将character_set_connection字符集转成相应的字符集存储到磁盘中,这个相应的字符集会按照以下优先级来判断:

1、创建表时设置的字符集

2、创建库时设置的字符集

3、character_set_database字符集

4、character_set_server字符集

查询数据:

服务端将数据由存储在磁盘中的字符集,转换成character_set_results字符集,返回给客户端

然后分析下

1、jdbc不设置characterEncoding=utf8,服务端character_set_server为latin1,jdbc以latin1字符集连接数据库,数据库服务端将latin1转成utf8然后存储到磁盘(因为character_set_connection和创建表指定的字符集都是utf8),这时就造成了乱码

2、jdbc不设置characterEncoding=utf8,服务端character_set_server为utf8,或者jdbc设置characterEncoding=utf8,jdbc都以utf8字符集连接数据库,数据库服务端以utf8存储到磁盘,这时数据就是正常的

到此这篇关于关于Java中使用jdbc连接数据库中文出现乱码的问题的文章就介绍到这了,更多相关jdbc连接数据库中文乱码内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 关于Java中使用jdbc连接数据库中文出现乱码的问题

本文链接: https://lsjlt.com/news/209468.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 关于Java中使用jdbc连接数据库中文出现乱码的问题
    目录一、使用jdbc连接数据库,插入数据库时,数据里的数据显示乱码,为 " "二、为什么配置了character_set_server = utf8,jdbc连...
    99+
    2023-05-15
    jdbc连接 jdbc连接数据库 数据库中文乱码
  • Java中使用jdbc连接数据库中文出现乱码如何解决
    今天小编给大家分享一下Java中使用jdbc连接数据库中文出现乱码如何解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、...
    99+
    2023-07-06
  • Idea连接MySQL数据库出现中文乱码的问题
    问题:当使用JDBC连接MySQL数据库时,插入中文显示乱码 解决方法:在连接代码中插入以下代码 String url = "jdbc:mysql://localhost:330...
    99+
    2024-04-02
  • 关于java中出现问号乱码问题的总结
    在基于Java的编程中,经常会碰到汉字的处里及显示的问题,比如一大堆乱码或问号。这是因为JAVA中默认的编码方式是UNICODE,而中国人通常使用的文件和DB都是基于GB2312或者BIG5等编码,故会出现此问题。下面是关于此类问题的总结。...
    99+
    2015-10-17
    java入门 java 问号 乱码 总结
  • 使用Idea连接MySQL数据库出现中文乱码如何解决
    使用Idea连接MySQL数据库出现中文乱码如何解决?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。问题:当使用JDBC连接MySQL数据库时,插入中文显示乱码解决方法:在连...
    99+
    2023-06-14
  • 关于mysql数据库连接编码问题
    前几天使用springboot做一个数据库查询功能,发现使用中文就无法查到数据,经过测试SQL语句是没有问题的,但是就是查询不到数据,一直显示为null。 后来,我灵机一动尝试了一下查询参数改为英文,显示出查询结果是正常...
    99+
    2023-04-14
    mysql数据库 mysql编码
  • Python连接数据库出现中文乱码如何解决
    Python连接数据库出现中文乱码如何解决,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。如何使用python exe?假设有一Python script 名为"hel...
    99+
    2023-06-17
  • 关于spring boot使用 jdbc+mysql 连接的问题
    1.创建文件,勾选JDBC和mysql pom.xml中添加了mysql驱动包和jdbc启动器 2.application.yml添加数据库的配置 spring: dataso...
    99+
    2024-04-02
  • 详细说明关于Java的数据库连接(JDBC)
    目录Java的数据库连接(JDBC)1、什么是JDBC2、JDBC的原理3、演示JDBC的使用4、数据库连接方式5、JDBC的查询6、SQL注入7、预处理查询7.1 查询 已解决注入...
    99+
    2024-04-02
  • 怎么在Java中使用JDBC连接数据库
    本篇文章给大家分享的是有关怎么在Java中使用JDBC连接数据库,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一、使用JDBC连接数据库1.使用JDBC-ODBC桥驱动程序连接...
    99+
    2023-06-06
  • java中向mysql数据库插入中文数据出现乱码
    数据库插入中文乱码首先需要排除的问题是,MySQL的默认字符集和对应database的字符集是什么通常为了以后的兼容性,建议将整个MySQL的默认字符集都设置成utf-8。可以使用以下命令查看默认字符集:mysql> SHOW VARIAB...
    99+
    2014-07-23
    java入门 java mysql 中文 乱码
  • Java中怎么利用JDBC实现数据库连接
    Java中怎么利用JDBC实现数据库连接,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。 JDBC:...
    99+
    2024-04-02
  • Java中使用JDBC连接数据库的示例代码与注意事项
    本篇内容主要讲解“Java中使用JDBC连接数据库的示例代码与注意事项”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java中使用JDBC连接数据库的示例代码与注意事项”吧!实例代码如下:&nb...
    99+
    2023-06-17
  • 如何解决使用Kettle抽取数据时出现中文乱码问题
    这篇文章主要介绍如何解决使用Kettle抽取数据时出现中文乱码问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 数据从oracle抽取到mysql,数...
    99+
    2024-04-02
  • 解决Java中文乱码问题:使用System.out.println输出中文字符串
    解决Java中文乱码问题:使用System.out.println输出中文字符串 在Java编程中,当我们想要在控制台输出中文字符串时,有时会遇到乱码的问题。本文将介绍如何解决这个问题,并提供相应的源...
    99+
    2023-10-25
    java python 开发语言 Java
  • Java使用JDBC连接数据库的详细步骤
    目录一、JDBC是什么?二、使用步骤1.注册驱动2.获取连接3.获取数据库操作对象4.执行sql语句5.处理查询结果集6.释放资源上述六步连贯:第一次优化:(比较两种注册驱动的方法)...
    99+
    2024-04-02
  • PHP如何解决数据库中文乱码问题?
    在使用PHP与数据库进行交互的过程中,中文乱码问题是常见的挑战之一。本文将介绍如何通过PHP解决数据库中文乱码问题,并提供具体的代码示例。 问题背景: 在与数据库进行数据存取时,中文字...
    99+
    2024-04-02
  • 解决js传中文参数到java后台出现乱码问题
    在js中传中文到java后端时,参数中有中文时,后端获取到的值是乱码。解决方法如下:先在js中传值时把参数编码,然后再传值到后端var userName=encodeURI(userName);在后端获取该值后,再用进行解码userName...
    99+
    2017-10-25
    java基础 解决 java 中文参数 问题 js
  • DBeaver使用——excel、csv数据导入中文乱码问题
    Navicat不让用了,就选择了平替DBeaver~ DBeaver不支持直接导入excel文件,可以先将excel文件转为csv格式。设置编码为“GB2312”(一般为默认)。(注:设置成其它格式也可,注意后面需要将DBeaver中的...
    99+
    2023-09-03
    开发语言 sql mysql 数据库
  • Java使用JDBC连接数据库的步骤是什么
    Java使用JDBC连接数据库的步骤是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、JDBC是什么?JDBC 指 Java 数据库连接(Java Database ...
    99+
    2023-06-22
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作