resultset 在数据库连接断开后是否可以被使用
来源:互联网 发布:node实现反向代理跨域 编辑:程序博客网 时间:2024/04/30 11:21
在Connection上调用close方法会关闭Statement和ResultSet吗?
级联的关闭这听起来好像很有道理,而且在很多地方这样做也是正确的,通常这样写
Connection con = getConnection();//getConnection is your method
PreparedStatement ps = con.prepareStatement(sql);
ResultSet rs = ps.executeQuery();
……
///rs.close();
///ps.close();
con.close(); // NO!
这样做的问题在于Connection是个接口,它的close实现可能是多种多样的。在普通情况下,你用DriverManager.getConnection()得到一个Connection实例,调用它的close方法会关闭Statement和ResultSet。但是在很多时候,你需要使用数据库连接池,在连接池中的得到的Connection上调用close方法的时候,Connection可能并没有被释放,而是回到了连接池中。它以后可能被其它代码取出来用。如果没有释放Statement和ResultSet,那么在Connection上没有关闭的Statement和ResultSet可能会越来越多,那么……
相反,我看到过这样的说法,有人把Connection关闭了,却继续使用ResultSet,认为这样是可以的,引发了激烈的讨论,到底是怎么回事就不用我多说了吧。(作者意思是:rs的资源没有释放,还用的是连接池中的conn)
所以我们必须很小心的释放数据库资源,下面的代码片断展示了这个过程
Connection con = null;
PreparedStatement ps = null;
ResultSet rs = null;
try {
con = getConnection();//getConnection is your method
ps = con.prepareStatement(sql);
rs = ps.executeQuery();
///...........
}
catch (SQLException ex) {
///错误处理
}
finally{
try {
if(ps!=null)
ps.close();
}
catch (SQLException ex) {
///错误处理
}
try{
if(con!=null)
con.close();
}
catch (SQLException ex) {
///错误处理
}
}
很麻烦是不是?但为了写出健壮的程序,这些处理是必须的。
大意如下:
如果不使用连接池机制, 关闭connection, 必然关闭resultset!
如果使用连接池, 所谓的关闭connection, 其实是将连接返回给了连接池,
连接对象依然存在, 所以这实际上不叫关闭!
2。Iterator aaItr= bbList.iterator();
有些书上又叫重复器或是迭代器,
Iterator aaItr中放的应该是bbList中所有的值
应该是bbList的一个幅本
- resultset 在数据库连接断开后是否可以被使用
- 在Asp中使用断开式数据库连接
- 关于使用ibm jdk时,在关闭statement,preparedstatement后是否需要关闭resultset WebSphere服务器
- 数据库连接断开后重新连接问题解决方案
- 如测试连接后的SOCKET是否还连在服务器上,是否断开了。
- 让程序可以在断开ssh连接后接着运行 screen
- 新手--从网络加载图片并存储在本地,断开网络后依然可以显示图片
- 断开数据库连接
- 测试对象销毁后指针是否还可以使用
- java开发中如何在ResultSet结果集关闭后,还能使用数据库数据。
- 数据库连接断开,数据库连接池报错问题
- SqlServer强制断开数据库连接
- 断开指定数据库连接
- SQLServer 断开数据库连接
- google Map 在手机上是否可以使用的判断
- JDBC数据库连接池connection关闭后Statement和ResultSet未关闭的问题
- JDBC数据库连接池connection关闭后Statement和ResultSet未关闭的问题
- JDBC数据库连接池connection关闭后Statement和ResultSet未关闭的问题
- C语言一句话知识
- Android 关于ListView几个特别的属性
- 关于嵌入式的学习之路
- python学习第五章
- java.util.Properties 配置文件
- resultset 在数据库连接断开后是否可以被使用
- POJ 1222 : EXTENDED LIGHTS OUT
- 用EXPLAIN PLAN 分析SQL语句
- linux中在多个文件中查找替换文本的shell脚本
- Oracle中null值的比较
- Android——AppWidgetProvider应用
- 走进c#(类型转换的一个类Object对象转int String double byte[] Stream)
- 项目管理总结
- awk ==