[tag:powerbuilder odbc mysql 中文乱码作者:benjaminz(zeng78@gmail.com) 时间:2008-11-14 由于一个项目中要使用mysql作为数据库,前端的开发工具定为powerbuilder9,安
由于Java的String类型使用的是unicode编码,而微软的Access数据库使用的是gbk编码。使用String类型的变量存储Access中的文本字段中文会发生乱码现象。[java 文件编码是UTF-8。所以我们需要转码。prop.put(charSet, gb2312);public static Connection getConnction() { Connection dbConnection = null; try {
使用byte[]类型可以解决这一问题。
1.更新到数据库的文本字段
使用ResultSet的updateBytes方法
public void updateBytes(StringcolumnName,
byte[] x)
throwsSQLException
String str="要写入数据库的中文";//utf-8
使用String的getBytes方法public byte[] getBytes(String charsetName)
throws UnsupportedEncodingException
转换编码格式为gbk
rs.updateBytes("columnName",str.getBytes("gbk"));
rs.updateRow();
这样写入Access数据库的中文字符便正常了;
2.从数据库字段读取文本
使用String类的构造函数
public String(byte[] bytes,StringcharsetName)
throwsUnsupportedEncodingException
str=new String(rs.getBytes("columnName"),"gbk");
这样读取到String中的中文字符便正常了。
上面就是解决Access数据文本字段和String类型间乱码问题的方法。
本质上说,就是编码类型不匹配。需要根据情况进行编码类型转换。
这是要有效的利用字节数据类型的方法,来达到目的,使用合适的API方法。[1.引言 Java与数据库的连接对于一些中大型的主流数据库而言,一般数据库厂商都提供了专门的JDBC驱动.但对于部分小型数据库而言经常没有专门的JDBC数据库连接驱动程序.但我