java+mysql中文乱码问题_MySQL

php中文网
发布: 2016-06-01 13:18:58
原创
1139人浏览过

bitsCN.com

乱码问题原因有多种,其中有一种是由于mysql默认使用 iso-8859-1 ( 即latin1 ) 字符集,而java内部使用unicode编码,因此在java中向mysql数据库插入数据时,或者读取数据时,都需要先转换一下编码方式。当然,如果可以直接修改配置文件的话,也可以解决乱码问题,然而某些情况下,我们并不能直接接触到配置文件(例如你是买的网上的空间),此时,我们可以采取编码格式转换的方法。

详细方法参考以下博客。

http://ghostgate.blog.163.com/blog/static/20570131200811442747326/

 

插入数据:

立即学习Java免费学习笔记(深入)”;

如:

...

String str="中文";

String sql = "insert into Tb (xxx) values (?)"

PreparedStatement pstmt = conn.prepareStatement(sql);

pstmt.setString(1,str);

pstmt.executeUpdate();

这样插入到Mysql数据库后,用mysql.exe连接查看数据可以看到,插入数据变成了几个“?”呈,也即成了乱码。

解决方法是:

《Freemarker生成静态html文件及中文乱码的问题》
《Freemarker生成静态html文件及中文乱码的问题》

《Freemarker生成静态html文件及中文乱码的问题》

《Freemarker生成静态html文件及中文乱码的问题》 319
查看详情 《Freemarker生成静态html文件及中文乱码的问题》

String str="中文";

str = new String(str.getBytes(),"ISO8859_1");         //加入此句,改变编码为iso-8859-1

String sql = "insert into Tb (xxx) values (?)"

PreparedStatement pstmt = conn.prepareStatement(sql);

pstmt.setString(1,str);

pstmt.executeUpdate(); 

 

读取数据:

方法与插入数据类似,如下:

...

String str = rs.getString(1);

str = new String(str.getBytes("ISO8859_1"));     //由ISO8859-1编码还原为JAVA内部默认字符集

//或者 str = new String(str.getBytes("ISO8859_1","GBK");

bitsCN.com
相关标签:
java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号