我正在编写一个使用 JDBC 连接到 Oracle 的核心 Java 程序。
- 我正在选择带有选择条件的第一个表以获取少量行 ID。我在结果集中选择了一些记录
- 现在我在一个while循环中循环结果集(while resultSet.next())
- 然后为 id 等于第一个结果集中的 id 的行选择我的第二个表
在这两个选择中,我都使用相同的 Statement 对象。运行程序时,我只获得第一行详细信息,然后 java 抛出结果集已关闭的错误
简而言之,我想知道是否可以在循环之前和循环内使用一个 Statement 对象?
下面是我的代码示例
allCOBbatchRSet=stmt.executeQuery("SELECT RECID FROM V_F_BATCH WHERE BATCH_STAGE IS NOT NULL");
while (allCOBbatchRSet.next())
{
BatchRSet=stmt.executeQuery("SELECT XMLRECORD FROM F_BATCH WHERE RECID="+cobBatchRecId);
BatchRSet.next();
............
}
它失败了,但有例外
java.sql.SQLException: Closed Resultset: next at
oracle.jdbc.driver.InsensitiveScrollableResultSet.ensureOpen(InsensitiveScrollableResultSet.java:109) at
oracle.jdbc.driver.InsensitiveScrollableResultSet.next(InsensitiveScrollableResultSet.java:398) at
com.manohar.t24.COBDetails.getCOBDetails(COBDetails.java:46)