Which should I close first, the PreparedStatement or the Connection?(我应该先关闭哪个,PreparedStatement 还是 Connection?)
问题描述
在 JDBC 中使用 PreparedStatement
时,我应该先关闭 PreparedStatement
还是先关闭 Connection
?我刚刚看到一个代码示例,其中首先关闭了 Connection
,但在我看来,首先关闭 PreparedStatement
似乎更合乎逻辑.
When using a PreparedStatement
in JDBC, should I close the PreparedStatement
first or the Connection
first? I just saw a code sample in which the Connection
is closed first, but it seems to me more logical to close the PreparedStatement
first.
是否有标准的、可接受的方式来执行此操作?有关系吗?关闭 Connection
是否也会导致 PreparedStatement
关闭,因为 PreparedStatement
与 Connection
对象直接相关?
Is there a standard, accepted way to do this? Does it matter? Does closing the Connection
also cause the PreparedStatement
to be closed, since the PreparedStatement
is directly related to the Connection
object?
推荐答案
声明.我希望你关闭(按顺序)
The statement. I would expect you to close (in order)
- 结果集
- 声明
- 连接
(并一路检查空值!)
即以反向顺序关闭.
如果你使用 Spring JdbcTemplate (或类似的)那么它将为您处理这个问题.或者,您可以使用 Apache Commons DbUtils 和 DbUtils.close()
或 DbUtils.closeQuietly()
.
If you use Spring JdbcTemplate (or similar) then that will look after this for you. Alternatively you can use Apache Commons DbUtils and DbUtils.close()
or DbUtils.closeQuietly()
.
这篇关于我应该先关闭哪个,PreparedStatement 还是 Connection?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:我应该先关闭哪个,PreparedStatement 还是 Connection?


基础教程推荐
- 如何使用 Stream 在集合中拆分奇数和偶数以及两者的总和 2022-01-01
- 首次使用 Hadoop,MapReduce Job 不运行 Reduce Phase 2022-01-01
- 在螺旋中写一个字符串 2022-01-01
- 如何在不安装整个 WTP 包的情况下将 Tomcat 8 添加到 Eclipse Kepler 2022-01-01
- 由于对所需库 rt.jar 的限制,对类的访问限制? 2022-01-01
- 如何强制对超级方法进行多态调用? 2022-01-01
- 如何对 HashSet 进行排序? 2022-01-01
- Java 中保存最后 N 个元素的大小受限队列 2022-01-01
- 如何使用 Eclipse 检查调试符号状态? 2022-01-01
- Spring Boot Freemarker从2.2.0升级失败 2022-01-01