由多次使用Statement实例引起的Result set already closed异常的解决方案
在不同版本的Weblogic平台上迁移应用,产生了很严重的JDBC驱动版本不兼容的问题。
但是归根究底是代码的问题,废话少说,上代码示例。
- .....
- //以下是问题代码
- ResultSet rs=null;
- Statement st=null;
- rs=st.executeQuery("...");
- while(rs.next())
- {
- String data=rs.getString("...");
- ...........
- ResultSet innerRS=null;
- innerRS=st.executeQuery(".....");//在ojdbc6.jar的实现中,这行代码会关闭rs对象。
- while(innerRS.next())
- {
- String innerData=innerRS.getString(".....");
- .......
- }
- }
- ......................
以上这段代码在使用jdbc-1.4.jar或者ojdbc14.jar这两个包时是没有问题的,前者是独立的JDBC包,后者是Weblogic9.2使用的包。
但是,如果使用ojdbc6.jar这个包时,问题就会出现了,异常为SQLException: Result set already closed.
个人推测,Oracle在jdbc-1.4.jar这个版本的JDBC实现中,并未遵守JDBC规范,因为Java规范中明确说道:
By default, only one ResultSet
object per Statement
object can be open at the same time. Therefore, if the reading of oneResultSet
object is interleaved with the reading of another, each must have been generated by differentStatement
objects. All execution methods in the Statement
interface implicitly close a statment's currentResultSet
object if an open one exists.
简单来说,就是如果使用同样的Statement执行两次executeQuery查询,那么之前返回的ResultSet对象都会被关闭。
而很明显,Oracle在其1.4的实现中并未遵循这个规范,而在6这个版本中又遵循了这个规范,所以会在迁移的时候是这个代码本身的问题暴露出来。
综上所述
解决方案一:
在迁移时,为你的应用指定具体的包,防止驱动不兼容的情况。但是这个方法通常很麻烦,因为会有可能在很隐蔽的地方使你指定的驱动不生效。
解决方案二:
修改代码,这个是根本的解决之道,只要保证创建了某个ResultSet实例的Statement实例,在这个ResultSet用完之前,不要再次使用就可以。
至于具体的代码怎样写,最佳实践的例子有很多,不多赘述,只提供上述问题代码的修正版:
- .....
- //以下是没有问题的代码
- ResultSet rs=null;
- Statement st=null;
- rs=st.executeQuery("...");
- while(rs.next())
- {
- String data=rs.getString("...");
- ...........
- ResultSet innerRS=null;
- Statement innerST=conn.createStatement();
- innerRS=innerST.executeQuery(".....");//在ojdbc6.jar的实现中,这行代码会关闭rs对象。
- while(innerRS.next())
- {
- String innerData=innerRS.getString(".....");
- .......
- }
- }
- ...................... 转:http://blog.csdn.net/sun9701210/article/details/6867366
由多次使用Statement实例引起的Result set already closed异常的解决方案的更多相关文章
- layui前端框架实例(修复官网数据接口异常问题)
layui前端框架实例,官网的实例会提示数据接口异常,已修复. 主要是修改数据表格,做一个可以用的实例,可以选中,编辑,删除等. gitee地址:https://gitee.com/pingg2019 ...
- 实例解读丨关于GaussDB ETCD服务异常
摘要:本文通过对ETCD服务异常问题分析,代码展示解决方案. 本文分享自华为云社区<[实例状态]GaussDB ETCD服务异常>,作者:酷哥. 首先确认是否是虚拟机.网络故障 虚拟机故障 ...
- 【oracle】Enterprise Manager 无法连接到数据库实例。下面列出了组件的状态---个人解决方案
最近在学习Oracle,平常喜欢使用EM查看数据库状态,但是在最近突然发现EM连接不上Oracle数据库了,不知道问题出在哪里,只好卸载了重装.但是,在使用了几天以后,又出现了相同的问题,于是下决心将 ...
- MyBatis 源码分析——生成Statement接口实例
JDBC的知识对于JAVA开发人员来讲在简单不过的知识了.PreparedStatement的作用更是胸有成竹.我们最常见用到有俩个方法:executeQuery方法和executeUpdate方法. ...
- junit4X系列--Statement
原文出处:http://www.blogjava.net/DLevin/archive/2012/05/11/377954.html.感谢作者的无私分享. 初次用文字的方式记录读源码的过程,不知道怎么 ...
- 《深入理解mybatis原理》 MyBatis的架构设计以及实例分析
作者博客:http://blog.csdn.net/u010349169/article/category/2309433 MyBatis是目前非常流行的ORM框架,它的功能很强大,然而其实现却比较简 ...
- statement对象与sql语句(新手)
本篇介绍读上篇代码中的疑惑点 实现简单网页上对数据内容进行增删改查,需要用到三个部分:jsp网页前端部分+java后台程序+数据库表 一.创建一个Statement (用于在已经建立数据库连接的基础上 ...
- 《深入理解mybatis原理1》 MyBatis的架构设计以及实例分析
<深入理解mybatis原理> MyBatis的架构设计以及实例分析 MyBatis是目前非常流行的ORM框架,它的功能很强大,然而其实现却比较简单.优雅.本文主要讲述MyBatis的架构 ...
- MyBatis的架构设计以及实例分析
MyBatis是目前非常流行的ORM框架,它的功能很强大,然而其实现却比较简单.优雅.本文主要讲述MyBatis的架构设计思路,并且讨论MyBatis的几个核心部件,然后结合一个sel ...
随机推荐
- 在Ubuntu下编译wpa_supplicant
最近在研究WiFi联盟的多屏互动协议Miracast,其中需要用到wpa_supplicant,编译中遇到了一些问题,经过一下午的折腾也都解决了,下面分享给各位. 一.编译需要用到三个库源码包,分别是 ...
- Filezilla Server 配置大全
一个开源.免费的FTP服务端程序,Windows 安装程序(0.9.50 beta):右键另存为. 首先说一下FTP的二种模式:主动模式(port mode)与被动模式(passive mode),网 ...
- 程序包com.sun.image.codec.jpeg不存在 问题的完美解决
原文地址:http://my.oschina.net/zb0423/blog/86507 在使用Hudson进行打包的过程中,因为我们使用了一个pdf文件产生缩略图的功能,倒置添加的源码文件在mave ...
- 理解Socket编程【转载】
“一切皆Socket!” 话虽些许夸张,但是事实也是,现在的网络编程几乎都是用的socket. ——有感于实际编程和开源项目研究. 我们深谙信息交流的价值,那网络中进程之间如何通信,如我们每天打开浏览 ...
- Java面试必备知识
JAVA面试必备知识 第一,谈谈final, finally, finalize的区别. 第二,Anonymous Inner Class (匿名内部类) 是否可以extends(继承)其它类,是否可 ...
- python 判断内网IP方法及实例应用
一.初衷: 一般在CMDB里会存储一台服务器的内网IP.管理IP.电信IP.联通IP,我们在使用的时候只需要拿到其中一个外网IP地址即可.那么我们就需要判断内网IP.管理IP并剔除掉,获取第一个外网I ...
- Chrome每次打開都要打開123.sogou.com
剛開始還以為中毒了,又是殺毒又是掃描的,最後發覺,原來就是chrome的一個設置被改了. Chrome->設置->啟動時 : 選打开特定网页或一组网页->設置網頁 , 將其中的123 ...
- bootstrap-下拉菜单
<!-- 1.给父级添加class为dropdown,或者给父级添加定位属性 2.给button添加data-toggle="dropdown"属性,并添加dropdown- ...
- JVM加载class文件的原理机制
Java中的所有类,都需要由类加载器装载到JVM中才能运行.类加载器本身也是一个类,而它的工作就是把class文件从硬盘读取到内存中.在写程序的时候,我们几乎不需要关心类的加载,因为这些都是隐式装载的 ...
- 苹果safari浏览器登陆时Cookie无法保存的问题
Safari浏览器不支持将非ASCII字符存入Cookie,所以中文在保存的时候就会出问题,分号(";")也不能存在Cookie中,所以需要通过方法去除内容中的分号,在Cookie ...