用户登录
用户注册

分享至

hibernate 结果集已耗尽

  • 作者: 大力茹
  • 来源: 51数据库
  • 2020-12-30
ResultSet rs=null; String str="select publish_id,publish_name,publish_time,publish_text from comment_tb order by publish_time desc "; query.connect(); rs=query.select(str); while(rs.next()){ %> .... 用户序号: 用户名: "> 以上当while循环完了后,游标已经移到最后,再调用rs就会出现异常,也就是上面说的“结果集已耗尽”



  你这个结果集应该设置为可滚动吧,
查了一哈,大概可以这样设置:

stat = conn.createstatement();
改为 stmt=conn.createstatement(resultset.type_scroll_insensitive,resultset.concur_read_only); 就可以了

分析: 异常出现于移动结果集的指针时,原因是在生成statement对象的时候提供的参数不同
无参数的那个方法使用的是默认参数,statement执行后得到的结果集类型为 resultset.type_forward_only.这种类型的结果集只能通过rs.next();方法逐条读取,使用其他方法就会报异常. 如果想执行一些复杂的移动结果集指针的操作就要使用其他参数了
顺便简单介绍一下各个参数:

1. resultset.type_forward_only (略)
2. resultset.type_scroll_insensitive 双向滚动,但不及时更新,就是如果数据库里的数据修改过,并不在resultset中反应出来。
3. resultset.type_scroll_sensitive 双向滚动,并及时跟踪数据库里的更新,以便更改resultset中的数据。
4. resultset.concur_read_only 只读取resultset
5. resultset.concur_updatable 用resultset更新数据库
软件
前端设计
程序设计
Java相关