您的位置:首页 > 编程语言 > Java开发

Java JDBC-ODBC 连接 Access 数据库 中文乱码解决

2010-08-11 20:51 721 查看
由于Java的String类型使用的是unicode编码,而微软的Access数据库使用的是gbk编码。使用String类型的变量存储Access中的文本字段中文会发生乱码现象。

使用byte[]类型可以解决这一问题。

1.更新到数据库的文本字段

使用ResultSet的updateBytes方法

public void updateBytes(String columnName,
byte[] x)
throws SQLException

String str="要写入数据库的中文";//utf-8

使用String的getBytes方法

[code]public byte[] getBytes(String charsetName) throws UnsupportedEncodingException

转换编码格式为gbk

rs.updateBytes("columnName",str.getBytes("gbk"));[/code]
rs.updateRow();

这样写入Access数据库的中文字符便正常了;

2.从数据库字段读取文本

使用String类的构造函数

public String(byte[] bytes,
String charsetName)
throws UnsupportedEncodingException

str=new String(rs.getBytes("columnName"),"gbk");

这样读取到String中的中文字符便正常了。

上面就是解决Access数据文本字段和String类型间乱码问题的方法。

本质上说,就是编码类型不匹配。需要根据情况进行编码类型转换。

这是要有效的利用字节数据类型的方法,来达到目的,使用合适的API方法。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: