栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Java 7自动资源管理JDBC(try-with-resources语句)

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java 7自动资源管理JDBC(try-with-resources语句)

try(Connection con = getConnection()) {   try (PreparedStatement prep = con.prepareConnection("Update ...")) {       //prep.doSomething();       //...       //etc       con.commit();   } catch (SQLException e) {       //any other actions necessary on failure       con.rollback();       //consider a re-throw, throwing a wrapping exception, etc   }}

根据oracle文档,您可以将try-
with-resources块与常规try块结合使用。IMO,以上示例捕获了正确的逻辑,即:

  • 如果没有问题,请尝试关闭PreparedStatement
  • 如果内部块出了问题,(无论是什么)回滚当前事务
  • 无论如何尝试关闭连接
  • 如果关闭连接时出现问题,则无法回滚事务(因为这是连接上的一种方法,现在处于不确定状态),因此请勿尝试

在Java 6及更早版本中,我将使用三重嵌套的try块集(外部try-finally,中间try-catch,内部try-
finally)来完成此操作。ARM语法确实使这个麻烦。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/449956.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号