Operation not allowed after ResultSet closed 结果集关闭异常

仅仅提供一个思路:

首先确保你的函数体中出现错误之前没有关闭ResultSet

然后,如果你用的是线程池,并且条件是如果线程存在则使用,线程不存在才新建的逻辑

那么由于每一次close都是将连接还给线程池而非销毁,每一次获取连接都是从线程池获取,可能是你拿到了已经关闭资源的线程

所以可以先使用原始JDBC进行尝试

转载于:https://www.cnblogs.com/akanga/p/11598069.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个错误通常发生在尝试从已关闭ResultSet 对象中获取数据时。ResultSet 是一个数据表的结果,当您从数据库中检索数据时,会生成一个 ResultSet 对象。当您完成使用 ResultSet 时,应该将其关闭。 如果您在关闭 ResultSet 对象之后尝试从它中获取数据,就会出现 "Operation not allowed after ResultSet closed" 错误。您需要确保在使用 ResultSet 对象之前打开它,并在使用完毕后关闭它。以下是一个示例: ```java Connection conn = null; PreparedStatement stmt = null; ResultSet rs = null; try { // 获取连接对象 conn = DriverManager.getConnection("mydatabase"); // 创建 PreparedStatement 对象 stmt = conn.prepareStatement("SELECT * FROM my_table"); // 执行查询操作,并获取结果 rs = stmt.executeQuery(); // 处理结果 while (rs.next()) { // 处理每一行数据 int id = rs.getInt("id"); String name = rs.getString("name"); // ... 其他操作 } } catch (SQLException e) { // 处理异常 } finally { // 关闭 ResultSet 对象 if (rs != null) { try { rs.close(); } catch (SQLException e) { // 处理异常 } } // 关闭 PreparedStatement 对象 if (stmt != null) { try { stmt.close(); } catch (SQLException e) { // 处理异常 } } // 关闭 Connection 对象 if (conn != null) { try { conn.close(); } catch (SQLException e) { // 处理异常 } } } ``` 在上面的示例中,我们在 try 块中打开了 ResultSet 对象,并在 finally 块中关闭了它。这样可以确保 ResultSet 对象在使用完毕后被正确关闭,避免出现 "Operation not allowed after ResultSet closed" 错误。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值