什么是关闭 ResultSet 的正确时间

Posted

技术标签:

【中文标题】什么是关闭 ResultSet 的正确时间【英文标题】:What is the right time to close ResultSet 【发布时间】:2014-12-06 15:58:04 【问题描述】:

我有一个 Java ResultSet,其中包含大量数据(但仍可能存储在 RAM 中),从数据库中检索。我将使用这些数据。从性能的角度来看,我是否应该将结果集内容复制到某个数据结构中,以便能够尽快关闭结果集并使用新容器中的数据,或者最好不要浪费时间直接从结果集中复制内容并使用数据?

【问题讨论】:

从性能的角度来看,您必须至少阅读一次结果。如果您需要多次遍历它,那么复制可能会更快。 【参考方案1】:

ResultSet 一次获取指定数量的行,具体取决于所使用的 JDBC 驱动程序和数据库。因此,如果您的查询返回一百万行,则并非所有百万行都驻留在内存中,除非您遍历 ResultSet 并将它们当然放入内存中。要直接回答您的问题,请在阅读完所需行后关闭 ResultSet,通常是在 ResultSet.next() 返回 false 时。

JDBC Developers Guide

【讨论】:

谢谢,因为检索到的数据很大,但仍可能完全存储在 RAM 中。 它不一定要存储在内存中,除非您的用例需要它。

以上是关于什么是关闭 ResultSet 的正确时间的主要内容,如果未能解决你的问题,请参考以下文章

在ResultSet.execute之后循环终止[重复]

Java ResultSet未正确关闭

为啥我在调用 ResultSet.refreshRow() 时会看到 NotUpdatable?

查找 ResultSet 列数? [复制]

在 Java 中处理 ResultSet 的有效方法

无效状态,ResultSet 对象已关闭