JDBC数据库连接池connection关闭后Statement和ResultSet未关闭的问题

转载 2017年04月14日 11:59:40

本文转自:http://k1121.iteye.com/blog/1279063


(1)    主要问题


针对关闭connection是否会自动关闭Statement和ResultSet的问题,以及Statement和ResultSet所占用资源是否会自动释放问题,JDBC处理规范或JDK规范中做了如下描述:

JDBC处理规范

JDBC. 3.0 Specification——13.1.3 Closing Statement Objects

An applicationcalls the method Statement.close to indicate that it has finished processing astatement. All Statement objects will be closed when the connection thatcreated them is closed. However, it is good coding practice for applications toclose statements as soon as they have finished processing them. This allows anyexternal resources that the statement is using to be released immediately.

Closing aStatement object will close and invalidate any instances of ResultSet producedby that Statement object. The resources held by the ResultSet object may not bereleased until garbage collection runs again, so it is a good practice toexplicitly close ResultSet objects when they are no longer needed.

These commentsabout closing Statement objects apply to PreparedStatement and CallableStatementobjects as well.

JDBC. 4.0 Specification——13.1.4 Closing Statement Objects

An applicationcalls the method Statement.close to indicate that it has finished processing astatement. All Statement objects will be closed when the connection that createdthem is closed. However, it is good coding practice for applications to closestatements as soon as they have finished processing them. This allows any externalresources that the statement is using to be released immediately.

Closing aStatement object will close and invalidate any instances of ResultSet producedby that Statement object. The resources held by the ResultSet object may not bereleased until garbage collection runs again, so it is a good practice to explicitlyclose ResultSet objects when they are no longer needed.

Once aStatement has been closed, any attempt to access any of its methods with theexception of the isClosed or close methods will result in a SQLException beingthrown.

These commentsabout closing Statement objects apply to PreparedStatement andCallableStatement objects as well.

规范说明:connection.close 自动关闭 Statement.close 自动导致 ResultSet 对象无效(注意只是 ResultSet 对象无效,ResultSet 所占用的资源可能还没有释放)。所以还是应该显式执行connection、Statement、ResultSet的close方法。特别是在使用connection pool的时候,connection.close 并不会导致物理连接的关闭,不执行ResultSet的close可能会导致更多的资源泄露。

JDK处理规范:

JDK1.4

Note: A ResultSet object is automatically closed by theStatement object that generated it when that Statement object is closed,re-executed, or is used to retrieve the next result from a sequence of multipleresults. A ResultSet object is also automatically closed when it is garbagecollected.

Note: A Statement object is automatically closed when it isgarbage collected. When a Statement object is closed, its current ResultSetobject, if one exists, is also closed.

Note: A Connection object isautomatically closed when it is garbage collected. Certain fatal errors alsoclose a Connection object.

JDK1.5

Releases this ResultSet object’sdatabase and JDBC resources immediately instead of waiting for this to happenwhen it is automatically closed.

Note: A ResultSet object isautomatically closed by the Statement object that generated it when thatStatement object is closed, re-executed, or is used to retrieve the next resultfrom a sequence of multiple results. A ResultSet object is also automaticallyclosed when it is garbage collected.

规范说明:

1.垃圾回收机制可以自动关闭它们;

2.Statement关闭会导致ResultSet关闭;

3.Connection关闭不一定会导致Statement关闭。


V6使用的是数据库连接池,Connection关闭并不是物理关闭,只是归还连接池,所以Statement和ResultSet有可能被持有,并且实际占用相关的数据库的游标资源,在这种情况下,只要长期运行就有可能报“游标超出数据库允许的最大值”的错误,导致程序无法正常访问数据库。

(2)    解决建议

(1)      由于垃圾回收的线程级别是最低的,为了充分利用数据库资源,有必要显式关闭它们,尤其是使用Connection Pool的时候;

(2)      最优经验是按照ResultSet,Statement,Connection的顺序执行close;

(3)      为了避免由于java代码有问题导致内存泄露,需要在rs.close()和stmt.close()后面一定要加上rs = null和stmt = null;

(4)      如果一定要传递ResultSet,应该使用RowSet,RowSet可以不依赖于Connection和Statement。Java传递的是引用,所以如果传递ResultSet,你会不知道Statement和Connection何时关闭,不知道ResultSet何时有效。

JDBC数据库连接池connection关闭后Statement和ResultSet未关闭的问题

(1)    主要问题  针对关闭connection是否会自动关闭Statement和ResultSet的问题,以及Statement和ResultSet所占用资源是否会自动释放问题,JDBC...
  • qiruiduni
  • qiruiduni
  • 2014年09月05日 13:41
  • 933

[疯狂Java]JDBC:Statement、ResultSet、连接资源自动关闭、Properties配置文件

1. 建立连接得到Connection对象后如何继续操作数据库?     1) 查询数据库就必须要执行SQL语句,可以通过Connection对象conn获取一个代表要提交给数据库的SQL语句的句柄,...
  • Lirx_Tech
  • Lirx_Tech
  • 2016年04月12日 11:23
  • 1695

JDBC数据库连接池connection关闭后Statement和ResultSet未关闭的问题

本文转自:http://k1121.iteye.com/blog/1279063 (1)    主要问题 针对关闭connection是否会自动关闭Statement和ResultSet的...
  • tanga842428
  • tanga842428
  • 2016年08月30日 19:28
  • 453

Connection、PreparedStatement、Statement、ResultSet是JDBC编程常用的接口,请分别简述它们的作用?

JDBC定义: JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的JavaAPI,可以为多种关系数据库提供统一访问,它由一组用Java语...
  • dingxingmei
  • dingxingmei
  • 2014年09月14日 16:09
  • 2197

(韩顺平讲解)jdbc学习(一)---jdbc简介、Statement、ResultSet、Connection的使用

Jdbc简介 jdbc 是sun 公司定义的一套访问数据库的规范( 接口 + 类),主要是放在 java.sql 包javax.sql 包.  原理图:   做jdbc开发的几个前提 1.import...
  • u012301841
  • u012301841
  • 2014年07月27日 17:30
  • 1159

使用JDBC过程中如何正确关闭connection

来看一段代码:import java.sql.*; /** * Created by N3verL4nd on 2017/4/17. */ public class JdbcDemo { ...
  • lgh1992314
  • lgh1992314
  • 2017年04月18日 15:38
  • 2082

怎样实现关闭connection时自动关闭Statement和ResultSet

转自:怎样实现关闭connection时自动关闭Statement和ResultSet 关闭数据连接时, 一定也要关闭Statement和ResultSet, 不然在并发量较大的时候可能...
  • diligentcat
  • diligentcat
  • 2017年07月27日 10:18
  • 271

大家来说一说关于jdbc的那些事情,关于Connection,Statement和ResultSet的关闭顺序

以下只是个人观点,毕竟楼主只是大三学生一枚。还有很多需要学习的地方。 最近在做一个jsp+servlet的程序。 用的是Oracle数据库,然后安装的时候很多东西都是默认值。 用servlet,...
  • u012916287
  • u012916287
  • 2014年12月23日 21:37
  • 4860

statement与resultset的对应关系

问题描述: 1,Connection是Statement的工厂,一个Connection可以生产多个Statement。 2,Statement是ResultSet的工厂,一个Statement却只...
  • hanghangde
  • hanghangde
  • 2015年12月06日 21:55
  • 1734

java开发中如何在ResultSet结果集关闭后,还能使用数据库数据。

众所周知,在java开发中,涉及到数据库操作时,总会需要一系列的连接数据库的操作类的实例化和使用,如Connection类,PreparedStatement类/Statement类还有ResultS...
  • Krishnna
  • Krishnna
  • 2016年10月30日 18:41
  • 1036
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JDBC数据库连接池connection关闭后Statement和ResultSet未关闭的问题
举报原因:
原因补充:

(最多只允许输入30个字)