- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我看了很多答案,但不幸的是没有一个回答我的问题,我仍然无法弄清楚为什么我要关闭 ResultSet
。
这是导致问题的 try
代码片段:
System.out.println(" System Info! @CHKMD5Files(): Found pre-existing details: "+TOTAL);
Statement stmMD5 = null;
Connection connMD5 = null;
ResultSet rs_MD5 = null;
String RESULTMD5 = null;
try {
connMD5 = DriverManager.getConnection("jdbc:sqlite:" + bkpPATH+ hostname + ".db");
stmMD5 = connMD5.createStatement();
connMD5.setAutoCommit(false);
while (ROWID <= TOTAL) {
rs_MD5 = stmMD5.executeQuery("SELECT md5 FROM details WHERE ROWID = '"+ROWID+"';");
RESULTMD5 = rs_MD5.getString("MD5");
skipBuffer.write(RESULTMD5);
skipBuffer.newLine();
skipBuffer.flush();
ROWID++;
}
System.out.println(" System Info! @CHKMD5Files(): Done with try");
} catch (Exception ex) {
System.out.println(" System Error! @CHKMD5Files (2): " + ex);
System.exit(5);
} finally {
if (stmMD5 != null){
stmMD5.close();
System.out.println(" System Info! @CHKMD5Files (2): Closing Statement(stmMD5)");
}
if (connMD5 != null) {
connMD5.close();
System.out.println(" System Info! @CHKMD5Files (2): Closing Connection(connMD5)");
}
skipBuffer.close();
}
}
看起来 while 循环甚至没有运行,因为如果我将 print 语句放入循环中则什么也不会返回。
最佳答案
当你想使用一个ResultSet
时,你必须调用next
方法首先将 ResultSet
的指针设置在结果的第一行。作为Javadoc该方法说:
A ResultSet cursor is initially positioned before the first row; the first call to the method next makes the first row the current row; ...
因此,如果您不调用它,则不会指向任何结果和 getString
方法(在 RESULTMD5 = rs_MD5.getString("MD5") 中使用);
) 将生成该异常。所以至少添加
rs_MD5.next()
在提取结果之前。 next
方法返回一个 boolean 值以指示它是否可以到达下一行。所以你可能想添加一个 if
语句来在提取任何列值之前检查该值是否为真,因为如果 next
无法到达下一行(并返回false) 它会将指针设置为无有效行(没有剩余行),如果您尝试访问结果,您将得到相同的错误(请参阅上面 next
的 javadoc 链接)。
但不幸的是,即使您添加对next
的调用,您也会在第二次迭代中遇到同样的错误,因为您不能使用相同的 Statement
- 执行不同查询的对象。每个Statement
对象只能产生一个ResultSet
。
要解决这个问题,你至少应该更换
rs_MD5 = stmMD5.executeQuery("SELECT md5 FROM details WHERE ROWID = '"+ROWID+"';");
与
rs_MD5 = connMD5.createStatement().executeQuery(
"SELECT md5 FROM details WHERE ROWID = '"+ROWID+"';"
);
但我建议您不这样做,因为创建一个新的 Statement
对象非常耗时(每个对象都必须在执行之前进行编译)。由于在每次迭代中唯一改变的是 ROWID
,因此在每次迭代中再次重新编译相同的东西将是一种可怕的时间浪费。所以使用 PreparedStatement
反而。它允许您使用仅编译一次的语句,并且可以通过在其中注入(inject)参数(编译后)来多次重复使用。要使用 PreparedStatement
,您应该这样做:
Connection conn = ... //Connection to your database
PreparedStatement ps = conn.preparedStatement("SELECT * FROM person WHERE name = ? AND age = ?");
//First search all persons with name "J.Baoby" and age = 5
ps.setString(1, "J.Baoby");
ps.setInt(2, 5);
ResultSet set1 = ps.executeQuery();
// Do something with it
// ....
//Now I need persons with name "Henry" and age = 25
ps.setString(1, "Henry");
ps.setInt(2, 25);
ResultSet set1 = ps.executeQuery();
// Do something with it
// ...
注入(inject)这些参数的方法是使用 setXXX
方法,第一个参数是“?”的索引(从 1 开始)。你想替换,第二个参数是值。 XXX
替换为您要注入(inject)的值的类型。您可以注入(inject)的参数类型有限,因此请查看 Java API首先在其中注入(inject)对象之前。您可以在 Java API 中找到有关 PreparedStatement
的更多信息或 on this site (还有更多示例)。
最后我想补充一点,您应该关闭所有 (JDBC) 资源(Connection
、Statement
、ResultSet
、PreparedStatement
, ...) 当你确定你不再需要它们时。您不释放的资源是您的 JVM 可以分配给其他东西的浪费资源。不关闭资源是一个坏习惯,可能会导致性能下降。
祝你好运!
关于java.sql.SQLException : ResultSet closed on sqlite 异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40913684/
在我的应用程序中,我必须获取记录并将它们放入二维数组中。我必须首先触发两个查询以找出计数,以便我可以初始化数组,其次是获取数据。它会导致性能下降。我需要提高性能的解决方案。 谢谢。 最佳答案 I ha
在 Zend Framework 应用程序中,它的构建与 ZF2 Getting Started tutorial 中的相册应用程序非常相似,我使用 ResultSet 对象将数据从模型通过 Cont
我是 java 和 SQL 新手,我重复了一个我不知道如何避免的问题: 假设我想创建两个executeQuery,一个在另一个内部,在getRequestsFromDB方法中我创建第一个execute
这个问题已经有答案了: Why should I call close() on a ResultSet and Connection instance? (4 个回答) 已关闭 7 年前。 使用完结
public List searchCourse(String name) { List list = null; Course course = null;
我正在使用两个不同的查询从两个表中选择数据。我正在使用一个连接和一个结果集。两个表都已填充,但第二个查询的 resultset.next() 返回 false,尽管它必须为 true。 我还尝试使用两
试图了解这里发生了什么。 DatabaseMetaData 返回一个空结果集,而实际上相同的 SQL 查询则不会。这不是主要问题,因为我使用第二个代码示例作为解决方法。 DatabaseMetaDat
假设我有多个结果集(每个结果集将引用数据库中的 1 行)(它们属于同一个表。)。现在我想创建合并的结果集,它将实习生拥有所有其他结果集。所以我的主要目标是创建一个组合的 ResultSet,它将指向以
我正在尝试将 influxdb 与我的应用程序集成并处理输出。我正在导入 InfluxDBClient 包以连接到在我的本地计算机上运行的 influx 实例。使用以“influxdb.results
我正在尝试创建一个框架来显示数据库中的所有电影名称,然后他们选择框架中的一行来执行另一个查询。 我有一个 ResultSet (rs),它接收查询执行的结果以选择电影名称。之后,我使用 SQLTabl
我有一个 Servlet,它使用返回 ResultSet 的静态实用程序方法。 在我的 Servlet 代码中,我有 ResultSet rs = SimpleSearch.searchByName(
在从 Postgres 或 Oracle 检索时间戳时(我们称之为 startDate),使用 resultSet.getString("startDate") 调用或 resultSet.getTi
全部, 对于名为Analyze 的类及其构造函数Analyze,该构造函数将Java JDBC Resultset 对象作为参数。 private Resultset analysisSet publ
m 尝试遍历 3 个结果集并比较它们的值。 bt 它抛出这个异常......有人可以帮助我了解我正在经历的地方吗?这是一段代码: java.lang.Object[] reconciledPaymen
我已经尝试使用谷歌搜索并在 SO 上查看了这些线程: java jdbc accessing multiple resultsets Open two resultsets simultaneousl
我在 SQLite 的 JDBC 驱动程序中遇到问题。 我正在使用 SELECT 语句执行查询。 如果我得到一个空的 ResultSet(0 行),那么我会在调用 getString(1) 时看到抛出
我正在尝试根据特定条件搜索表格。在 SQL Developer 中执行时,SQL 查询返回正确的结果(1 行)。在 JDBC 中,resultset 不为 null,但 resultset.next(
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 4 年前。 Improve this ques
我正在尝试在 Java 应用程序中处理大量数据。数据存储在 MySQL 数据库中,我使用的是 jdbc 连接器 8.0.11。 我的问题是我需要多次访问每条记录并且再次执行查询需要太多时间。使用 Re
这个问题已经有答案了: Getting java.sql.SQLException: Operation not allowed after ResultSet closed (2 个回答) 已关闭
我是一名优秀的程序员,十分优秀!