from http://blog.csdn.net/iamoyjj/article/details/5805327
由于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方法
public byte[] getBytes(String charsetName)
throws UnsupportedEncodingException转换编码格式为gbkrs.updateBytes("columnName",str.getBytes("gbk"));
rs.updateRow();
这样写入Access数据库的中文字符便正常了;
2.从数据库字段读取文本
使用String类的构造函数
public String(byte[] bytes,
String charsetName)
throws UnsupportedEncodingException
str=new String(rs.getBytes("columnName"),"gbk");
这样读取到String中的中文字符便正常了。
上面就是解决Access数据文本字段和String类型间乱码问题的方法。
本质上说,就是编码类型不匹配。需要根据情况进行编码类型转换。
这是要有效的利用字节数据类型的方法,来达到目的,使用合适的API方法。
评论:
使用str=new String(rs.getBytes("columnName"),"gbk");
从Access数据库读取数据时,如果遇到空字段时,getBytes()返回null,此时接着进行String转换,会出现nullpoint异常.
因此需要判断getBytes()的返回结果是否为空 ,不为空的情况下才能进行转换.
可以如下判断:
byte[] bts=null;
String other = null;
bts = rs.getBytes("OTHERS"); //读取other字段
if(bts != null) other = new String(bts,"gbk");//如果不为空,则进行转换
注意此时不能使用equals(null)进行判断是否为空,
也即不能用bts.equals(null)进行判断,这样判断同样抛出nullpointer异常.
因为getBytes如果读取空字段,返回空指针.