关于怎样关闭Connection,ResultSet,PreparedStatement

legend8888 2007-10-18 09:44:08

方法1:
try {
if (rs != null) {
rs.close();
}
if (p != null) {
p.close();
}
if (connection != null) {
connection.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
方法2:
try {
if (rs != null) {
rs.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
Try{
if (p != null) {
p.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
Try{
if (connection != null) {
connection.close();
}
} catch (SQLException e) {
e.printStackTrace();
}




哪一个更好
...全文
219 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
zzdong 2007-10-18
  • 打赏
  • 举报
回复
try {
} catch() {
} finally {
if (rs != null) {
rs.close();
rs = null;
}
if (p != null) {
p.close();
p = null;
}
if (connection != null) {
connection.close();
connection = null;
}
}
个人认为这样会更好一点
legend8888 2007-10-18
  • 打赏
  • 举报
回复
bao110908
如果在关闭rs,p的时候出现异常怎么办?
zhb_821012 2007-10-18
  • 打赏
  • 举报
回复
后一个更好
关闭一般不会出异常
节省性能
legend8888 2007-10-18
  • 打赏
  • 举报
回复
对性能上有什么作用?
在关闭rs,p的时候会不会出现异常?
  • 打赏
  • 举报
回复
第一个更好,使用 try 块会产生大量的时间消耗,对于会产生异常的程序应尽量放置在一个 try 块里。
yuyu622 2007-10-18
  • 打赏
  • 举报
回复
后面一个更好,try - catch分得更细一些.
  • 打赏
  • 举报
回复
对性能上有什么作用?
在关闭rs,p的时候会不会出现异常?
______________

只要把方法 1 的代码,整个搬到 finally 块中就可以了。

62,623

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧