MySQL出现 Operation not allowed after ResultSet closed错误

今天测试增删查改的删除操作时,出现以下Operation not allowed after ResultSet closed的错误

原代码如下:

public static boolean insertUser(UserDTO _user) throws SQLException{
		boolean bool =false;
		Connection conn =null;
		Statement stmt = null;
        ResultSet res = null;
		conn = DataAccesss.getConnection();
		stmt = conn.createStatement();
		
		
		res = stmt.executeQuery("select * from userr where uname ='"+_user.getUname()+"'");//先查询数据库中是否存在该用户名,无论是软删除或仍存在不能插入。
		if(res.next()==false) {
			int num = stmt.executeUpdate("insert into userr values ('"+_user.getUname()+"','"+_user.getUpassword()+"','"+_user.getTel()+"','"+_user.getSurperuser()+"','"+_user.getFlag()+"')");
			System.out.println("已成功执行"+num+"行插入成功");
			
		}
		else {System.out.println("用户名已存在");}
		if(res.getInt("flag")==1) 
			System.out.println("该用户被软删除,存在数据库中");
		
		DataAccesss.closeConnection(conn, stmt,res);
		return bool=true;
	}
	

这是由于多个一个stmt多个rs进行操作引起的ResultSet已经关闭的错误

一个stmt多个rs进行操作.
那么从stmt得到的rs1,必须马上操作此rs1后,才能去得到另外的rs2,再对rs2操作.
不能互相交替使用,会引起rs已经关闭错误.

/* 插入功能
	 * 参数列表传入userr实例
	 * 往表格最后输入一行元祖
	 * 打印插入行数插入是否成功
	 * (需要修改权限,用户自己可以设置自己权限??!!)
	 */
	public static boolean insertUser(UserDTO _user) throws SQLException{
		boolean bool =false;
		Connection conn =null;
		Statement stmt = null;
        ResultSet res = null;
		conn = DataAccesss.getConnection();
		stmt = conn.createStatement();
		
		
		res = stmt.executeQuery("select * from userr where uname ='"+_user.getUname()+"'");//先查询数据库中是否存在该用户名,无论是软删除或仍存在不能插入。
		if(res.next()==false) {
			int num = stmt.executeUpdate("insert into userr values ('"+_user.getUname()+"','"+_user.getUpassword()+"','"+_user.getTel()+"','"+_user.getSurperuser()+"','"+_user.getFlag()+"')");
			System.out.println("已成功执行"+num+"行插入成功");
			bool=true;
			
		}
		else {System.out.println("用户名已存在");
		if(res.getInt("flag")==1) 
			System.out.println("该用户被软删除,存在数据库中");}
		
		DataAccesss.closeConnection(conn, stmt,res);
		return bool;
	}

 

一个stmt最好对应一个rs, 如果用一个时间内用一个stmt打开两个rs同时操作,会出现这种情况.
所以解决此类问题:1.就多创建几个stmt,一个stmt对应一个rs;2.若用一个stmt对应多个rs的话,那只能得到一个rs后就操作,处理完第一个rs后再处理其他的

 

stmt=conn.createStatement();
stmt2=conn.createStatement();
rs=stmt.executeQuery("select * from t1");
rst=stmt2.executeQuery("select * from t2");
rs.last();
rst.last();
--------------------- 
 

 

 

 

 

 

 

这个错误通常发生在尝试从已关闭的 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、付费专栏及课程。

余额充值