博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java JDBC-ODBC 连接 Access 数据库 中文乱码解决
阅读量:4030 次
发布时间:2019-05-24

本文共 1206 字,大约阅读时间需要 4 分钟。

from  http://blog.csdn.net/iamoyjj/article/details/5805327

由于Java的String类型使用的是unicode编码,而微软的Access数据库使用的是gbk编码。使用String类型的变量存储Access中的文本字段中文会发生乱码现象。

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

 

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

使用ResultSet的updateBytes方法

public void updateBytes( columnName,                        byte[] x)                 throws
String str="要写入数据库的中文";//utf-8
使用String的getBytes方法 public byte[] getBytes( charsetName)                throws 转换编码格式为gbk rs.updateBytes("columnName",str.getBytes("gbk"));
rs.updateRow();
这样写入Access数据库的中文字符便正常了;

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

使用String类的构造函数

public String(byte[] bytes,               charsetName)       throws
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如果读取空字段,返回空指针.

你可能感兴趣的文章
除了负载均衡,Nginx还可以做很多,限流、缓存、黑白名单
查看>>
解析zookeeper的工作流程
查看>>
搞定Java面试中的数据结构问题
查看>>
深入理解Apache Flink核心技术
查看>>
SpringCloud 各组件原理图,面试必备
查看>>
面试题总结:可能是全网最好的MySQL重要知识点
查看>>
MySQL面试之数据库索引
查看>>
完整的项目管理流程,看清PMP42个过程的执行顺序
查看>>
设计模式,面试速记手册1
查看>>
设计模式,面试速记手册2
查看>>
备受面试官青睐的 Java NIO,到底和传统 IO 有啥不一样
查看>>
各大公司Java面试题超详细总结
查看>>
搞定MySQL之面经(一)
查看>>
排序算法,看这一篇就够了,含动图+Java实现
查看>>
性能指标:QPS、TPS、系统吞吐量理解
查看>>
搞清 适配器模式、代理模式和装饰者模式的不同
查看>>
一次完整的HTTP请求过程
查看>>
HTTP 与 HTTPS 的区别
查看>>
SVN E200030: There are unfinished transactions detected
查看>>
搞定Nginx高并发原理:多进程单线程和多路IO复用模型
查看>>