java.sql.SQLException:对只转发结果集的⽆效操作:last
java.sql.SQLException: 对只转发结果集的⽆效操作: last
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:111)at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:145)at oracle.jdbc.driver.BaseResultSet.last(BaseResultSet.java:81)
at com.ambow.upgrade.comm.UpGradeService.deleteOpr(UpGradeService.java:568)at com.ambow.upgrade.comm.UpGradeService.loadData(UpGradeService.java:126)at com.ambow.upgrade.comm.UpGradeService.exeUpgrade(UpGradeService.java:519)at com.ambow.upgrade.comm.UpGradeService.main(UpGradeService.java:528)
JAVA代码:
pstmt = sourceConn.prepareStatement(findSql);pstmt.executeUpdate();rs = pstmt.executeQuery();
rs.last();//移到最后⼀⾏ 出错代码⾏
int rowCount = rs.getRow(); //得到当前⾏号,也就是记录数
rs.beforeFirst(); //还要⽤到记录集,就把指针再移到初始化的位置
出错原因见这⾥:
因为初学,所以,在建⽴Statement时使⽤默认参数。导致在使⽤执⾏rs.last()时,产⽣“java.sql.SQLException:对只转发结果集的⽆效操作:last”的异常。
最后在建⽴Statement时加⼊相关参数,就可以解决了。 操作查询结果集的过程中出现异常
出现异常的语句: rs.last();
异常的详细信息:对只转发结果集的⽆效操作: last
解决办法: stat = conn.createStatement();
改为 stmt=conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); 就可以了
分析: 异常出现于移动结果集的指针时,原因是在⽣成statement对象的时候提供的参数不同
⽆参数的那个⽅法使⽤的是默认参数,statement执⾏后得到的结果集类型为 ResultSet.TYPE_FORWARD_ONLY.这种类型的结果集只能通过rs.next();⽅法逐条读取,使⽤其他⽅法就会报异常. 如果想执⾏⼀些复杂的移动结果集指针的操作就要使⽤其他参数了 顺便简单介绍⼀下各个参数:
ResultSet.TYPE_FORWARD_ONLY (略)
ResultSet.TYPE_SCROLL_INSENSITIVE 双向滚动,但不及时更新,就是如果数据库⾥的数据修改过,并不在ResultSet中反应出来。 ResultSet.TYPE_SCROLL_SENSITIVE 双向滚动,并及时跟踪数据库⾥的更新,以便更改ResultSet中的数据。 ResultSet.CONCUR_READ_ONLY 只读取ResultSet ResultSet.CONCUR_UPDATABLE ⽤ResultSet更新数据库
修改后的代码:
pstmt = sourceConn.prepareStatement(findSql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY);pstmt.executeUpdate();
rs = pstmt.executeQuery();rs.last();//移到最后⼀⾏
int rowCount = rs.getRow(); //得到当前⾏号,也就是记录数
rs.beforeFirst(); //还要⽤到记录集,就把指针再移到初始化的位置