笨鸟先飞之Java--MySql中文数据乱码为哪般???

从开始敲drp到现在的hibernate,中文数据乱码无时无刻不“陪伴”在我的身边:

图一:在drp的分销商模块,每次修改区域虽然返回修改成功,但是每次读取到的中文数据都是“???”的字符串,但数字和字母的数据却不受影响。

图二:不管是drp还是hibernate项目,通过执行sql或者hql语句插入中文数据的,都会呈现图中的景象,甚是无语。。。。。。

但被它困扰了这么久,我也算“久病成医”,今天就一起来给Java项目医治一下中文数据乱码的这个大病。

在哲学上有句话“头痛医头,脚痛医脚”,但这是一个错误的观点。因为头痛不一定只是头出现了问题,这个插入数据乱码也是一样的道理,所以我们不能单单地把问题归结到MySql身上,或者怪罪到Java程序上。下面大家就和我一起踏上探索“数据乱码”的征途:

?
第一站:开发环境的中文字符集

在drp的开发过程中,在分销商维护模块中,每次修改分销商信息时,数据可以完美地插入,但是数据库中的中文都是“???”这样的字符串,导致读取出来的数据也是乱码。这时我们要进行一步步的排查,先从开发环境下手,打开myeclipse中的window,执行如下操作:

这样就可以保证我们开发环境为GB18030;[PS:GB18030:国家标准,信息技术 中文编码字符集]

? 第二站:将Navicat和开发环境的字符集设置保持一致

在上面的图中,我们对开发环境设置了中文编码的字符集,可能会解决一部分人遇到的问题,但是依旧没有解决我的问题。所以我要继续探索!

使用Navicat软件,打开你要使用的数据库的表,右击--选择”设计表“:

选中要输入中文数据的字段,对它的属性进行如下设置:

将这一步完成,可能是你的解决方案,但还不是我的;怎么办??凉拌,继续出发向前:

? 第三站:"method"中get的乱入

我们经常会对某个方法的method进行设置,在这里传输数据时使用post可以避免get方式带来的乱码。

? 第四站:连接数据库的配置文件中缺少“约束”

(这里有hibernate.cfg.xml和User.properties文件两种)

在"沙漠"中经过几站的长途跋涉,我终于看到一眼清泉:通过对配置文件进行少许的更改,便可以一解我的燃眉之急:

方式一:使用.xml文件对数据库进行配置:

<span style="font-family:FangSong_GB2312;font-size:18px;"><hibernate-configuration>
	<session-factory>
		<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
		<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/hibernate_cache</property>
		<property name="hibernate.connection.username">root</property>
		<property name="hibernate.connection.password"></property>
		<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
		<property name="hibernate.show_sql">true</property>
</sessionFactory></span>

在connection.url行只是书写数据库的地址和相应的数据库名称,却没有对中文字符集进行配置,所以要对这行代码进行如下修改:

<span style="font-family:FangSong_GB2312;font-size:18px;"><property name="hibernate.connection.url">jdbc:mysql://localhost:3306/hibernate_extends?useUnicode=true&amp;characterEncoding=UTF-8</property>
</span>

我们可以注意到,变化的是数据库名之后跟上的那句用来设置中文字符集的代码,但是这里有几个注意点

1.不要让中文问号“鱼龙混珠”

数据库名之后的问号一定是英文状态下的,如果是中文状态的,那么在执行这个配置文件时,中文状态的问号会被myeclipse译成三个问号,就会发出“配置语句错误”的提示;

2.一个都不能少

useUnicode=true之后跟着的一定是“&amp;",这五个元素一个都不能少,但是一般情况下,直接在网页中将这五个元素复制粘贴到配置文件中,会只显示一个“&”:这样控制台就会打印:“Encoding应该以分号结束”,这个错误不是要在最后加上分号,而是注意这五个元素的“一个都不能少!”

方式二:使用.properties文件进行配置:

<span style="font-family:FangSong_GB2312;font-size:18px;">jdbc.driver = com.mysql.jdbc.Driver
jdbc.url = jdbc:mysql:///shop
jdbc.user = root
jdbc.password =123</span>

这种情况出现乱码时,就对jdbc.url进行如下更改:

<span style="font-family:FangSong_GB2312;font-size:18px;">jdbc.url = jdbc:mysql:///shop?useUnicode=true&characterEncoding=UTF-8</span>

这样我们就完成了每一个环节的中文字符集设置,也就解决了Java程序的“中文乱码问题”这个大弊病了。

到这里,这次的沙漠探索之行就结束了,解决错误不是目的,目的是要在解决错误的过程中进行分析和思考,不被表象所蒙蔽,进而不犯“头痛医头脚痛医脚”的错误,也就是老师经常给我们讲到的全局观----“不谋全局者不足谋一隅,不谋万世者不足谋一时!”

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-12-24 01:51:33

笨鸟先飞之Java--MySql中文数据乱码为哪般???的相关文章

从内存中写入mysql中文数据乱码解决

一. 问题 数据库编码:utf8 mysql> create database dbnameDEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci; 表编码:utf8 drop table if exists `test`; create table `test` ( `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'ID', `name` varchar(50) default '', `create

关于JAVA写入MYSQL中文数据乱码问题的处理

1.检查JDBC中mysql的驱动是否加上了这个: jdbc:mysql://localhost:3306/db_book?useUnicode=true&characterEncoding=UTF-8 2.查看JAVA的IDE是否为UTF-8编码 3.查看数据库是否UTF-8编码 原文地址:https://www.cnblogs.com/liuyuxing1024/p/10384771.html

通过g++查询到的mysql中文数据输出是乱码

这几天遇到一个问题: 通过g++查询到的mysql中文数据输出是乱码,而通过g++添加到mysql中的中文数据也是乱码,但单独通过g++输出正常,查询通过mysql添加的中文数据显示也正常. 在网查查询了很久,纠结了半天也没有找到答案.后来通过在linux吧发帖终于找到了解决方案.原来是mysql和g++默认字符集不匹配产生的问题.通过在代码中添加 int mysql_set_character_set(MYSQL *mysql, char *csname)函数终于解决了问题. 源码如下: #i

WEB应用常见中文数据乱码问题总结

在实际工作中,会遇到很多中文数据的乱码的问题,之所以会产生乱码,就是因为服务器和客户端沟通的编码不一致造成的,因此解决的办法是:在客户端和服务器之间设置一个统一的编码,之后就按照此编码进行数据的传输和接收. 1.以POST方式提交表单中文参数的乱码问题 客户端是以UTF-8字符编码将表单数据传输到服务器端,因此服务器也需要设置以UTF-8字符编码进行接收,服务器可以直接使用从ServletRequest接口继承而来的"setCharacterEncoding(charset)"方法进行

提交中文数据乱码问题总结

提交中文数据乱码问题总结 1.如果提交方式为post,想不乱码,只需要在服务器端设置request对象的编码即可,客户端以哪种编码提交的,服务器端的request对象就以对应的编码接收,比如客户端是以UTF-8编码提交的,那么服务器端request对象就以UTF-8编码接收(request.setCharacterEncoding("UTF-8")) 2.如果提交方式为get,设置request对象的编码是无效的,request对象还是以默认的ISO8859-1编码接收数据,因此要想不

as3+java+mysql(mybatis) 数据自动工具(七) - 完结

autoscript packed 文件地址:http://pan.baidu.com/s/1dDvgcO5 如果需要项目源码的话,可以留下邮箱,先声明一下,该工具主要是为了实现自动同步输出代码类文件的功能,所以代码写得并不是很规范什么的,没太大的参考意义,主要还是工具的实用性. 数据类和常量的配置基本就是前面所说明的那些了,现在来说一下怎么执行配置文件.执行配置文件需要写一个批处理文件,格式如下 java -classpath ./lib/*; AutoScript -? 这是一个执行 jav

c#写入Mysql中文显示乱码 解决方法 z

mysql字符集utf8,c#写入中文后,全部显示成?,一个汉字对应一个? 解决方法:在数据库连接字符串中增加字符集的说明,Charset=utf8,如 MySQLConnection con = new MySQLConnection("server=127.0.0.1;uid=root;pwd=;database=test;Charset=utf8"); 搞定 c#写入Mysql中文显示乱码 解决方法 z,布布扣,bubuko.com

as3+java+mysql(mybatis) 数据自动工具(六)

这篇来写一些常量定义的实例.我一般在配置常量的时候,都会让 bitOffset = 20,这样是一个比较好的分配,就是每个分组可以有 0xFFFFF(1048575) 个常量,0xFFF(4095) 个分组. 游戏中的客户端和服务端都需要的游戏常量,如下 <macros name="MacroDefine" author="idoublewei" note="常量宏定义"> <macro name="ACCOUNT_R

as3+java+mysql(mybatis) 数据自动工具(五)

现在介绍常量的配置,主要用于客户端(as3)与服务端(java)之间的常量同步,比如错误码.请求标识等 配置格式: <macros name="Macros" groupStart="16" groupEnd="128" bitOffset="20" author="idoublewei" note="宏定义"> <macro name="SEX_MALE&q