ResultSet的遍历方法

ResultSet的遍历方法ResultSet 遍历两种方法 第一 直接迭代 第二 用第三方工具类第一 直接迭代 1 DQL 代码不同于前面的 DML 过程的是 将原来的 sql 语句改成 DQL 并且调用 statement 的 executeQuery 方法执行查询 返回结果使用 ResultSet 进行接收 Stringsql select fromstudent ResultSetrs stm

ResultSet遍历两种方法,第一,直接迭代,第二,用第三方工具类

第一:直接迭代:

1.DQL代码

String sql = "select * from student"; ResultSet rs = stmt.executeQuery(sql);

这个rs保存了查询返回的结果集,并没有读取出来呢,究竟怎么读呢?首先让我们了解一下ResultSet

2.ResultSet 的功能

这个ResultSet 究竟是个什么鬼呢?查看API文档之后,总结如下:

2.1 ResultSet 对象具有指向其当前数据行的光标。 最初,光标被置于第一行之前。调用 next() 方法将光标移动到下一行;next()方法一开始是处于第一行之前,即beforeFirst,第一次使用next()就将指针指向返回结果集的第一行。每使用一次next(),指针就指向下一行。

       因为该方法在 ResultSet 对象没有下一行时返回 false, 所以可以在 while 循环中使用它来迭代结果集,调用getXXX(int fieldIndex)/getXXX(String columnName)方法获取字段值。

2.2 ResultSet 接口提供用于从当前行获取列值的获取方法(getBoolean、getLong 等)。

可以使用列的索引编号或列的名称获取值。一般情况下,使用列索引较为高效。列从 1开始编号。为了获得最大的可移植性,应该按从左到右的顺序读取每行中的结果集列, 每列只能读取一次。

2.3 用作获取方法的输入的列名称不区分大小写

3.写代码读取ResultSet

3.1 读取方法1 – 通过索引来遍历读取

while(rs.next()){ int id = rs.getInt(1); String name = rs.getString(2); String gender = rs.getString(3); System.out.println("id:"+id+" 姓名:"+name+" 性别:"+gender); }

3.2 读取方法2 – 通过字段名称来读取

强调一下,这个传入的字段名称可以不区分大小写,因为在mysql中就是不区分的

while(rs.next()){ int id = rs.getInt("id"); String name = rs.getString("name"); String gender = rs.getString("gender"); System.out.println("id:"+id+" 姓名:"+name+" 性别:"+gender); }

第二:调用三方工具类

直接使用BeanHandler
 ,就可以简化大部分代码

BeanHandler 
  
    bh =new BeanHandler 
   
     (Student.class); //rs是ResultSet得到的从返回集合 Student li = bh.handle(rs); 
    
  

BeanHandler

是返回一个实体对象,BeanListHandler

是返回一个list实体集合,MapHandler是返回不确定的单个实体对象,MapListHandler是返回不确定的list实体集合。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/215193.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月18日 下午2:28
下一篇 2026年3月18日 下午2:29


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号