中文显示问题一直是困扰我们的一个难题,不信你上google搜索一下,这类的问题和解答可以说是铺天盖地,好多网站甚至将其提出来作为专题来讨论,管中窥豹,可见一斑。
开始也曾为这个问题头疼,上网查阅大量的资料和解决方法,终于找到了一种既简单又好用的办法,以JSP+MYSQL存储为例,简单介绍一下。
当页面<!---->使用GBK(或者GB2312)编码后,页面中的中文都可以正常显示(<!---->)。但是涉及到数据库的存取时,您常常会看到令人头疼的乱码。输出SQL执行的字符串,例如:insert into table values('1','旺财','20','男'); 这时候可以看到显示的都是中文,但是当你打开数据库查看记录的时候看到还是乱码,晕!为什么?如果这时候你从MYSQL控制台命令行下输入上面的语句执行时,再查看数据库记录,咦!没有问题呀,执行同样的语句,为什么得到不一样的结果呢?看来JDBC是难脱其咎了。
简而言之解决方法:
连接数据库时:jdbc:mysql://localhost/test?user=root&password=&useUnicode=true&characterEncoding=ISO-8859-1",指明编码为ISO-8859-1,我看了一下MYSQL的相关文件,它默认的编码就是ISO-8859-1,但是在这里不指明的话还是有问题,中文仍旧不能正常显示(到底为什么其实我也不是很清楚)。这样在往数据库中存放的时候就正常了。
从数据库中读取数据时,如果用rs.getString("name")的话,乱码又出来了,这还是一个编码转换的问题,下面给一个转换函数:
<%
/********************************************
函数名:toGB
作 用:将ISO8859字符集转换为GB2312字符集
解决数据库中文显示问题
参 数:iso ----要转换的字符串
返回值: gb ----转换后的字符串
********************************************/
%>
<%! public String toGB(String iso)
{
String gb=null;
if (iso != null) {
try {
gb=new String(iso.getBytes("ISO-8859-1"),"GB2312");
} catch (Exception e) {
gb=null;
}
}
return gb;
}
%>
分享到:
相关推荐
MySQL数据库系统中文乱码问题及解决方案.pdf
MySQL数据库中文参考手册(CHM)
MySQL数据库教程光盘+mySql中文手册 MySQL数据库教程光盘+mySql中文手册
MySQL数据库设计、优化 叶金荣 微博: @yejinrong 微信公众号: MySQL中文网 QQ群: 125572178、272675472 2013.08.20 MySQL数据库设计、优化全文共24页,当前为第1页。 提纲 规范 基础规范 命名规范 库表规范 字段...
MySQL数据库中文参考手册(CHM).rar
<br> DB2MYSQL能够实现可视化操作数据库,转换界面非常简单明了,可轻松实现ACCESS数据库转换为MYSQL数据库。如果想要将SQL SERVER的数据库转换到MYSQL,也可以使用这个软件,具体操作是先使用SQL SERVER的...
linux下mysql数据库乱码问题
<br>mysql数据库的网页管理工具,使用方法 http://主机名/mysql 注意,进入后先选择中文界面。 <br>该管理工具的使用需具有一定数据库基础,请勿进行危险操作,以免导致数据丢失。 <br>另外,为了防止...
常用的汉字,拼音数据库,基本包含了所有汉字,字段:汉字、繁体字、拼音、笔画、解释、更多等 里面有两个sql文件,一个包含了常用的汉字,另一个包含了几乎所有的汉字库
MYSQL数据库中文乱码问题.docx
使用Struts实现了向MySQL数据库中存储图片的功能。有一些问题没能解决:中文乱码问题,上传图片不能太大等等。虽然不太完善,作为参考还是可以的
在DELPHI中使用MyDAC连接MySQL数据库时中文显示乱码的解决方法。
mysql数据库中文乱码问题共2页.pdf.zip
mysql数据库DBA宝典手册,中文版,可以说是学习mysql系统管理的完美宝典
简单轻便的mysql管理工具,支持中文!!
解决knime连接mysql数据库中文乱码
包含16142个汉字,基本包含了所有汉字,字段:汉字、繁体字、拼音、笔画、解释、更多等
如何解决MYSQL数据库中文乱码问题-.docx
从 MT4 (MQL4) 访问 MySQL 数据库(支持中文读取写入)带范例源码,MQL通过调用 接口库 MQLMySQL.mqh. 使用 #include 语句将它加到项目工程里。它包含的指令用于导入 MQLMySQL.dll 动态库的函数,以及调用它们和处理...