返回顶部
首页 > 资讯 > 精选 >Java中使用jdbc连接数据库中文出现乱码如何解决
  • 270
分享到

Java中使用jdbc连接数据库中文出现乱码如何解决

2023-07-06 03:07:09 270人浏览 薄情痞子
摘要

今天小编给大家分享一下Java中使用jdbc连接数据库中文出现乱码如何解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、

今天小编给大家分享一下Java中使用jdbc连接数据库中文出现乱码如何解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

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

两种解决方案:

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

使用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的字符集

Java中使用jdbc连接数据库中文出现乱码如何解决

解释下这几个参数:

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服务,再去查询字符集:

Java中使用jdbc连接数据库中文出现乱码如何解决

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

插入数据:

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

创建表时设置的字符集

创建库时设置的字符集

character_set_database字符集

character_set_server字符集

查询数据:

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

然后分析下

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

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

以上就是“Java中使用jdbc连接数据库中文出现乱码如何解决”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网精选频道。

--结束END--

本文标题: Java中使用jdbc连接数据库中文出现乱码如何解决

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

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

猜你喜欢
  • Java中使用jdbc连接数据库中文出现乱码如何解决
    今天小编给大家分享一下Java中使用jdbc连接数据库中文出现乱码如何解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、...
    99+
    2023-07-06
  • 关于Java中使用jdbc连接数据库中文出现乱码的问题
    目录一、使用jdbc连接数据库,插入数据库时,数据里的数据显示乱码,为 " "二、为什么配置了character_set_server = utf8,jdbc连...
    99+
    2023-05-15
    jdbc连接 jdbc连接数据库 数据库中文乱码
  • Python连接数据库出现中文乱码如何解决
    Python连接数据库出现中文乱码如何解决,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。如何使用python exe?假设有一Python script 名为"hel...
    99+
    2023-06-17
  • 使用Idea连接MySQL数据库出现中文乱码如何解决
    使用Idea连接MySQL数据库出现中文乱码如何解决?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。问题:当使用JDBC连接MySQL数据库时,插入中文显示乱码解决方法:在连...
    99+
    2023-06-14
  • 使用ajax获取数据出现中文乱码如何解决
    本篇文章为大家展示了使用ajax获取数据出现中文乱码如何解决,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。使用scriptCharset即可解决问题,用conten...
    99+
    2024-04-02
  • Idea连接MySQL数据库出现中文乱码的问题
    问题:当使用JDBC连接MySQL数据库时,插入中文显示乱码 解决方法:在连接代码中插入以下代码 String url = "jdbc:mysql://localhost:330...
    99+
    2024-04-02
  • JDBC中如何连接数据库
    这篇文章主要为大家展示了“JDBC中如何连接数据库”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JDBC中如何连接数据库”这篇文章吧。连接数据库的步骤:注册驱动...
    99+
    2024-04-02
  • mysql数据库中文乱码如何解决
    mysql数据库中文乱码的解决方法:更改数据库安装时的字符编码。打开mysql安装目录。找到my.ini文件,以记事本的方式打开。直接修改配置文件的字符编码为utf8。default-character-set=utf8character-...
    99+
    2024-04-02
  • oracle数据库中文乱码如何解决
    解决Oracle数据库中文乱码问题的步骤如下:1. 确保数据库字符集设置正确:使用以下命令查询当前数据库的字符集设置:```sele...
    99+
    2023-08-23
    oracle数据库
  • 怎么在Java中使用JDBC连接数据库
    本篇文章给大家分享的是有关怎么在Java中使用JDBC连接数据库,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一、使用JDBC连接数据库1.使用JDBC-ODBC桥驱动程序连接...
    99+
    2023-06-06
  • oracle数据库出现乱码如何解决
    在Oracle数据库中出现乱码可能是由于字符集不匹配或者数据插入时使用了错误的字符集引起的。以下是一些解决方法: 确保数据库字符集...
    99+
    2024-04-09
    oracle
  • python中jdbc如何连接数据库
    在Python中,可以使用`pyodbc`库来连接数据库。以下是一个连接MySQL数据库的示例:```pythonimport py...
    99+
    2023-08-23
    python jdbc 数据库
  • java数据库中文乱码解决方法
    mysql是我们项目中非常常用的数据型数据库。但是因为我们需要在数据库保存中文字符,所以经常遇到数据库乱码情况。下面我们来看一下解决java向数据库插入数据时出现乱码的解决方法。在数据库的配置的url后加useUnicode=true&ch...
    99+
    2015-04-27
    java 数据库 乱码
  • 详解Java使用JDBC连接MySQL数据库
    一:什么是数据库,为什么要有数据库? 数据,数据库,数据库管理系统和数据库系统是与数据库技术密切相关的四个基本概念。 数据库相信大家都耳熟能详了,其实数据库顾名思义就是存放数据的仓库...
    99+
    2024-04-02
  • postgresql中出现中文乱码如何解决
    postgresql中出现中文乱码的解决方法:1.启动postgresql服务;2.登录postgresql数据库;3.使用数据库;4.使用show命令查看数据库编码;5.使用set命令将数据库编码修改为GBK;具体步骤如下:首先,在命令行...
    99+
    2024-04-02
  • SpringMVC中出现中文乱码如何解决
    SpringMVC中出现中文乱码如何解决?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。表单<%@ page contentType="t...
    99+
    2023-06-14
  • Samba中出现中文乱码如何解决
    今天就跟大家聊聊有关Samba中出现中文乱码如何解决,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Samba显示中文乱码,添加下面的内容到smb.conf中client code p...
    99+
    2023-06-07
  • Python中出现中文乱码如何解决
    今天就跟大家聊聊有关Python中出现中文乱码如何解决,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。在Python 中文乱码中提到unicode,一般指的是unicode对象,例如&...
    99+
    2023-06-17
  • java中向mysql数据库插入中文数据出现乱码
    数据库插入中文乱码首先需要排除的问题是,MySQL的默认字符集和对应database的字符集是什么通常为了以后的兼容性,建议将整个MySQL的默认字符集都设置成utf-8。可以使用以下命令查看默认字符集:mysql> SHOW VARIAB...
    99+
    2014-07-23
    java入门 java mysql 中文 乱码
  • 在php中使用mssql出现中文乱码如何解决
    这篇文章给大家介绍在php中使用mssql出现中文乱码如何解决,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。php显示mssql中文乱码的解决办法:1、根据页面情况来设置utf-8编码;2、直接在程序中通过iconv函...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作