笨鸟先飞之Java--MySql中文数据乱码为哪般???
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了笨鸟先飞之Java--MySql中文数据乱码为哪般???,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含4271字,纯文字阅读大概需要7分钟。
内容图文
![笨鸟先飞之Java--MySql中文数据乱码为哪般???](/upload/InfoBanner/zyjiaocheng/456/d9689bdf0b054fc69e1c4abe714020fe.jpg)
图一:在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&characterEncoding=UTF-8</property> </span>我们可以注意到,变化的是数据库名之后跟上的那句用来设置中文字符集的代码,但是这里有几个注意点:
1.不要让中文问号“鱼龙混珠”
数据库名之后的问号一定是英文状态下的,如果是中文状态的,那么在执行这个配置文件时,中文状态的问号会被myeclipse译成三个问号,就会发出“配置语句错误”的提示;
2.一个都不能少
useUnicode=true之后跟着的一定是“&",这五个元素一个都不能少,但是一般情况下,直接在网页中将这五个元素复制粘贴到配置文件中,会只显示一个“&”:这样控制台就会打印:“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程序的“中文乱码问题”这个大弊病了。
到这里,这次的沙漠探索之行就结束了,解决错误不是目的,目的是要在解决错误的过程中进行分析和思考,不被表象所蒙蔽,进而不犯“头痛医头脚痛医脚”的错误,也就是老师经常给我们讲到的全局观----“不谋全局者不足谋一隅,不谋万世者不足谋一时!”
版权声明:本文为博主原创文章,未经博主允许不得转载。
笨鸟先飞之Java--MySql中文数据乱码为哪般???
标签:乱码 java
本文系统来源:http://blog.csdn.net/ysc1123/article/details/48004933
内容总结
以上是互联网集市为您收集整理的笨鸟先飞之Java--MySql中文数据乱码为哪般???全部内容,希望文章能够帮你解决笨鸟先飞之Java--MySql中文数据乱码为哪般???所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。