解读ResultSet的遍历方法

 更新时间:2023年02月28日 09:09:24   作者:爱吃牛肉的大老虎  
这篇文章主要介绍了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<T> ,就可以简化大部分代码

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

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

ResuSet遍历结果集

先找到位置,再获取数据

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

刚开始游标的位置:

在这里插入图片描述

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

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();

    }
}

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Java中BufferedReader和BufferedWriter使用方式

    Java中BufferedReader和BufferedWriter使用方式

    这篇文章主要介绍了Java中BufferedReader和BufferedWriter使用方式,FileWriter 类从 OutputStreamWriter 类继承而来,BufferedReader 类从字符输入流中读取文本并缓冲字符,以便有效地读取字符,数组和行
    2022-06-06
  • SpringBoot实现识别图片中的身份证号与营业执照信息

    SpringBoot实现识别图片中的身份证号与营业执照信息

    这篇文章主要为大家详细介绍了SpringBoot如何实现识别图片中的身份证号与营业执照信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2024-01-01
  • IDEA的Swing可视化插件JFormDesigner详解

    IDEA的Swing可视化插件JFormDesigner详解

    JFormDesigner是一个专业的软件应用程序,专门用于帮助您开发Java Swing用户界面,而无需具备编程技能。它可作为独立实用程序使用,也可以将其用作各种IDE的插件,本文给大家介绍idea Swing可视化插件,感兴趣的朋友一起看看吧
    2022-06-06
  • 深入理解Java中的构造函数引用和方法引用

    深入理解Java中的构造函数引用和方法引用

    java构造函数,也叫构造方法,是java中一种特殊的函数。函数名与相同,无返回值。方法引用是用来直接访问类或者实例的已经存在的方法或者构造方法。下面我们来详细了解一下它们吧
    2019-06-06
  • Java权重随机的实现方法

    Java权重随机的实现方法

    这篇文章主要介绍了Java权重随机的实现方法,实例分析了权重随机算法的原理与完整实现方法,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-01-01
  • SpringBoot原理之自动配置机制详解

    SpringBoot原理之自动配置机制详解

    Springboot遵循“约定优于配置”的原则,使用注解对一些常规的配置项做默认配置,减少或不使用xml配置,让你的项目快速运行起来,下面这篇文章主要给大家介绍了关于SpringBoot原理之自动配置机制的相关资料,需要的朋友可以参考下
    2021-11-11
  • Hadoop之NameNode Federation图文详解

    Hadoop之NameNode Federation图文详解

    今天小编就为大家分享一篇关于Hadoop之NameNode Federation图文详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • SpringBoot为啥不用配置启动类的实现

    SpringBoot为啥不用配置启动类的实现

    这篇文章主要介绍了SpringBoot为啥不用配置启动类的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • SpringBoot顶层接口实现类注入项目的方法示例

    SpringBoot顶层接口实现类注入项目的方法示例

    本文主要介绍了SpringBoot顶层接口实现类注入项目的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-06-06
  • java应用cpu占用过高问题分析及解决方法

    java应用cpu占用过高问题分析及解决方法

    这篇文章主要介绍了java应用cpu占用过高问题分析及解决方法,具有一定参考价值,需要的朋友可以参考下。
    2017-09-09

最新评论