在Java中做到真正安全的释放数据库资源

王朝java/jsp·作者佚名  2006-01-08
宽屏版  字体: |||超大  

在Connection上调用close方法会关闭Statement和ResultSet吗?

级联的关闭这听起来好像很有道理,而且在很多地方这样做也是正确的,通常这样写

Connection con = getConnection();//getConnection is your method

PreparedStatement ps = con.prepareStatement(sql);

ResultSet rs = ps.executeQuery();

……

[url=file://rs.close][/url]///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,认为这样是可以的,引发了激烈的讨论,到底是怎么回事就不用我多说了吧。

所以我们必须很小心的释放数据库资源,下面的代码片断展示了这个过程

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) {

///错误处理

}

}

很麻烦是不是?但为了写出健壮的程序,这些处理是必须的。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有