WEB开发网
开发学院数据库sqlite sqlite 存取中文的解决方法 阅读

sqlite 存取中文的解决方法

 2013-09-08 15:09:50 来源:WEB开发网   
核心提示: SQLITE中文编码转换的问题终于解决了,从数据库取的时候直接用rs.getBytes("username")取得byte[],sqlite 存取中文的解决方法,而不是用rs.getString("username")取STRING,通过取得的BYTE来转即可以得到正常的中文,

 SQLITE中文编码转换的问题终于解决了。


从数据库取的时候直接用rs.getBytes("username")取得byte[],而不是用rs.getString("username")取STRING。


通过取得的BYTE来转即可以得到正常的中文,否则怎么转都是乱码。


byte[] val = rs.getBytes(cols_name);
data.put(cols_name, new String(val,"GBK"));


java 编码 UTF-8、ISO-8859-1、GBK


关键字: java utf-8、iso-8859-1、gbk
java 编码 UTF-8、ISO-8859-1、GBK


Java支持UTF-8、ISO-8859-1、GBK等各种字体编码,可笔者发现Java中字体编码的问题仍难倒了不少程序员,网上虽然也有不少关于在Java中如何正确显示中文的文章,但都不够全面,笔者特意总结如下。


影响Java中字体编码正确显示的有几个因素: 1)数据库的连接方式; 2)网页中使用的字体编码; 3)数据库里存放数据的字体编码; 4)Java的缺省字体编码。如果在编程中遇到不能正确显示中文时,要先弄清楚以上几项所使用的字体编码,再分析找出原因,即可解决问题。


众所周知,JSP是Java的一种,和网页有关,而网页也有自己的中文编码系统,所以JSP处理中文要比纯Java的类文件更为麻烦。本文的测试数据库是MySQL3.2,数据库连接驱动是用org.gjt.mm.mysql.Driver,这里主要讨论UTF-8和GBK的显示( GB2312是GBK的一个子集,Java中可以使用GBK来代替GB系列)。我们先来研究JSP中字体编码问题,下面第一到第六点是针对JSP的(因为从数据库里读出中文数据与写入中文数据有所区别,咱们分别说明,前三点是从读取数据库到显示在网页,后三点是从网页输入数据到存入数据库),第七到第九点针对纯Java的类文件。以下rs表示ResultSet的一个实例,是执行Select语句之后产生的数据集。


一、数据库连接方式使用UTF-8


在连接数据库的驱动后面加上这句参数useUnicode=true&characterEncoding=


UTF-8,例如jdbc:mysql://localhost/DBVF?autoReconnect=true&useUnicode=


true&characterEncoding=UTF-8,从数据库里读出中文显示在使用GBK的JSP的网页里,如果数据库里存放的字体编码是UTF-8,在JSP中使用 str=new String(rs.getBytes(1),"UTF-8")或者str=rs.getString(1),可以正确显示中文。如果数据库里存放的是 GBK数据,那么JSP中也要使用str=new String(rs.getBytes(1),"GBK")来显示正确的中文。值得注意的是如果页面使用UTF-8,数据库里存放的是UTF-8,也可以用str=new String(rs.getBytes(1),"GBK")正确显示中文。如果网页是UTF-8,而数据库里存放的是GBK,无法直接显示中文,需要2步转换, str=new String(rs.getBytes(1),"GBK"); 再str=new String(str.getBytes("UTF-8"),"GBK"),才可以正确显示中文。


二、数据库连接方式使用GBK


在连接数据库的驱动后面加上这句参数useUnicode=true&characterEncoding=


GBK,例如jdbc:mysql://localhost/DBVF?autoReconnect=true&UseUnicode=true&


characterEncoding=GBK,从数据库里读出中文,显示在使用GBK的JSP的网页里,如果数据库里存放的字体编码是 UTF-8,在JSP中一定要使用 str=new String(rs.getBytes(1),"UTF-8"),才正确显示中文。如果数据库里存放的是GBK数据,那么JSP中也要使用str=new String(rs.getBytes(1),"GBK") 或者直接使用str=rs.getString(1),即可显示正确的中文。如果网页是UTF-8,而数据库里存放的是GBK,只能用str=new String(rs.getString(1).getBytes("UTF-8"),"GBK")的方法来显示中文; 如果网页是UTF-8,而数据库里存放的是UTF-8,可用str=new String(rs.getBytes(1),"GBK") 或者rs.getString(1)方法来显示中文。

1 2 3  下一页

Tags:sqlite 存取 解决

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接