您好,欢迎来到刀刀网。
搜索
您的当前位置:首页java.sql.SQLException:对只转发结果集的无效操作:last

java.sql.SQLException:对只转发结果集的无效操作:last

来源:刀刀网
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(); //还要⽤到记录集,就把指针再移到初始化的位置

因篇幅问题不能全部显示,请点此查看更多更全内容

Copyright © 2019- gamedaodao.com 版权所有 湘ICP备2022005869号-6

违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务