验证码: 看不清楚,换一张 查询 注册会员,免验证
  • {{ basic.site_slogan }}
  • 打开微信扫一扫,
    您还可以在这里找到我们哟

    关注我们

ResultSet的遍历方法有哪些

阅读:409 来源:乙速云 作者:代码code

ResultSet的遍历方法有哪些

      ResultSet的遍历方法

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

      第一:直接迭代

      1.DQL代码

      不同于前面的DML过程的是,将原来的sql语句改成DQL,并且调用statement的executeQuery() 方法执行查询,返回结果使用ResultSet 进行接收。

      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实体集合。

      ResuSet遍历结果集

      先找到位置,再获取数据

      • next():作用是使游标下移,返回的是布尔型,判断当前行是否是最后一行末尾(是否有数据),如果是,返回false,反之则返回ture。

      刚开始游标的位置:

      ResultSet的遍历方法有哪些

      用循环判断游标是否在最后一行:

      while (rs.next()){ 
          String id=rs.getString(1);    
          String name=rs.getString(2);    
          int age=rs.getInt(3);    
          String sex=rs.getString(4);    
          System.out.println(id +"--"+ name+"--"+age+"--"+sex);}

      JDBC查询数据库信息

      package cn.cast.jdbc;
      
      import java.sql.*;
      
      public class JdbcDemo4 {
          public static void main(String[] args) throws ClassNotFoundException, SQLException {
           //注册驱动
           Class.forName("com.mysql.cj.jdbc.Driver");
           //获取数据库连接对象
            Connection conn= DriverManager.getConnection("jdbc:mysql:///stu?serverTimezone=GMT","root","root");
            //定义sql语句
              String sql="select * from ss";
              //获取执行sql的对象
              Statement stmt=conn.createStatement();
              //执行sql
              ResultSet rs=stmt.executeQuery(sql);
              //处理结果(以next返回值判断是否在最后一行,然后获取数据)
              while (rs.next()){
                  String id=rs.getString(1);
                  String name=rs.getString(2);
                  int age=rs.getInt(3);
                  String sex=rs.getString(4);
                  System.out.println(id +"--"+ name+"--"+age+"--"+sex);
              }
              //释放资源
              rs.close();
              stmt.close();
              conn.close();
      
          }
      }
    分享到:
    *特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: hlamps#outlook.com (#换成@)。
    相关文章
    {{ v.title }}
    {{ v.description||(cleanHtml(v.content)).substr(0,100)+'···' }}
    你可能感兴趣
    推荐阅读 更多>