当前位置: 首页 > 编程笔记 >

解决Java程序使用MySQL时返回参数为乱码的示例教程

穆才良
2023-03-14
本文向大家介绍解决Java程序使用MySQL时返回参数为乱码的示例教程,包括了解决Java程序使用MySQL时返回参数为乱码的示例教程的使用技巧和注意事项,需要的朋友参考一下

先说MySQL的字符集问题。Windows下可通过修改my.ini内的 

default-character-set=utf8  //客户端的默认字符集

在MySQL客户端工具中输入

SHOW VARIABLES LIKE 'character%'; 

显示如下

这样执行读取信息返回中文为乱码,解决办法是,在连接数据库之后,读取数据之前,先执行一项查询 SET NAMES 'utf8'; 即可显示正常。

最简单的完美修改方法,修改mysql的my.cnf文件中的字符集键值(注意配置的字段细节):

1、在[client]字段里加入default-character-set=utf8,如下:

port = 3306 
socket = /var/lib/mysql/mysql.sock 
default-character-set=utf8 

2、在[mysqld]字段里加入character-set-server=utf8,如下:

port = 3306 
socket = /var/lib/mysql/mysql.sock 
character-set-server=utf8 

3、在[mysql]字段里加入default-character-set=utf8,如下:

no-auto-rehash 
default-character-set=utf8 

修改完成后,service mysql restart重启mysql服务就生效。注意:[mysqld]字段与[mysql]字段是有区别的。这点在网上没人反馈过。

使用SHOW VARIABLES LIKE ‘character%';查看,发现数据库编码全已改成utf8。

+--------------------------+----------------------------+ 
| Variable_name | Value | 
+--------------------------+----------------------------+ 
| character_set_client | utf8 | 
| character_set_connection | utf8 | 
| character_set_database | utf8 | 
| character_set_filesystem | binary | 
| character_set_results | utf8 | 
| character_set_server | utf8 | 
| character_set_system | utf8 | 
| character_sets_dir | /usr/share/mysql/charsets/ | 
+--------------------------+----------------------------+ 


4、如果上面的都修改了还乱码,那剩下问题就一定在connection连接层上。解决方法是在发送查询前执行一下下面这句(直接写在SQL文件的最前面):

SET NAMES ‘utf8′; 

它相当于下面的三句指令:

SET character_set_client = utf8; 
SET character_set_results = utf8; 
SET character_set_connection = utf8; 


网上很多其他方法不能彻底解决这个问题,这个可以完美解决!

 类似资料:
  • 本文向大家介绍解决nodejs中使用http请求返回值为html时乱码的问题,包括了解决nodejs中使用http请求返回值为html时乱码的问题的使用技巧和注意事项,需要的朋友参考一下 今天用nodejs进行http请求时返回的数据是一个html文件,然后我还是按照以前解析json数据的方法。果不其然报错了:SyntaxError: Unexpected token  in JSON at po

  • 本文向大家介绍Python程序中使用SQLAlchemy时出现乱码的解决方案,包括了Python程序中使用SQLAlchemy时出现乱码的解决方案的使用技巧和注意事项,需要的朋友参考一下 今天对clubot进行了升级, 但是导入数据后中文乱码, 一开是找资料说是在创建引擎的时候添加编码信息: 但是这并不行, 然后查看表信息: 发现原来创建表的时候用的latin1编码, 而老的表是用utf-8编码创

  • 本文向大家介绍php解决DOM乱码的方法示例代码,包括了php解决DOM乱码的方法示例代码的使用技巧和注意事项,需要的朋友参考一下 前言 DOM是php比较新的xml和html处理类,可以像javascript那样方便的操作DOM树,网上更多的是介绍它处理XML的情况,今天这篇文章就介绍下php解决DOM乱码的方法,下面话不多说,直接看下面的解决方法。 解决方法如下 总结 以上就是这篇文章的全部内

  • 本文向大家介绍MYSQL数据库使用UTF-8中文编码乱码的解决办法,包括了MYSQL数据库使用UTF-8中文编码乱码的解决办法的使用技巧和注意事项,需要的朋友参考一下 1.用phpmyadmin创建数据库和数据表 创建数据库的时候,请将“整理”设置为:“utf8_general_ci” 或执行语句: 创建数据表的时候:如果是该字段是存放中文的话,则需要将“整理”设置为:“utf8_general_

  • 本文向大家介绍JQuery ajax 返回json时出现中文乱码该如何解决,包括了JQuery ajax 返回json时出现中文乱码该如何解决的使用技巧和注意事项,需要的朋友参考一下 使用jQuery ajax调用的返回json,中文乱码问题 Js代码如下: Js代码 Java代码  代码很简单就不做解释了。有问题请给我留言,我会在第一时间给大家取得联系。

  • 本文向大家介绍php写入mysql中文乱码的实例解决方法,包括了php写入mysql中文乱码的实例解决方法的使用技巧和注意事项,需要的朋友参考一下 php写入mysql出现中文乱码的解决办法是:在建立数据库连接之后,将该连接的编码方式改为中文。 代码如下: 继续上面的问题,查看一下Apache目录下的PHP源文件,发现页面的编码方式是ANSI的,于是乎,我改成了utf8格式的。然后在执行SQL语句