我的编程空间,编程开发者的网络收藏夹
学习永远不晚

解读ResultSet的遍历方法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

    }
}

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

解读ResultSet的遍历方法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

解读ResultSet的遍历方法

这篇文章主要介绍了ResultSet的遍历方法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-02-28

ResultSet的遍历方法有哪些

这篇文章主要介绍“ResultSet的遍历方法有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“ResultSet的遍历方法有哪些”文章能帮助大家解决问题。ResultSet的遍历方法Result
2023-07-05

Go语言的Channel遍历方法详解

先来看看基本的定义: channel是Go语言中的一个核心类型,可以把它看成管道。并发核心单元通过它就可以发送或者接收数据进行通讯,这在一定程度上又进一步降低了编程的难度。 channel是一个数据类型,主要用来解决go程的同步问题以及协程
2022-06-07

遍历ArrayList的三种方法

遍历 ArrayList 可以使用以下三种方法:1. 使用 for 循环遍历:可以使用 for 循环结合 ArrayList 的 size() 方法,遍历每个元素。```javaArrayList list = new ArrayList(
2023-09-14

Python遍历文件夹和读写文件的实现方法

需 求 分 析 1、读取指定目录下的所有文件 2、读取指定文件,输出文件内容 3、创建一个文件并保存到指定目录 实 现 过 程 Python写代码简洁高效,实现以上功能仅用了40行左右的代码~ 昨天用Java写了一个写入、创建、复制、重命
2022-06-04

JS异步遍历的实现方法

本文主要介绍了JS异步遍历的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-05-17

c++ set遍历的方法是什么

在C++中,可以使用迭代器或者范围循环来遍历Set。1. 使用迭代器遍历Set:```cpp#include #include int main() {std::set mySet = {1, 2, 3, 4, 5};// 使用迭代器遍历S
2023-09-15

python遍历数组的两种方法

python遍历数组的两种方法第一种,最常用的,通过for in遍历数组[cpp] view plain copycolours = ["red","green","blue"]  for colour in colours:      p
2023-01-31

jquery有哪些遍历方法

遍历方法有:1、add(),用于把元素添加到匹配元素的集合中;2、children(),用于返回被选元素的所有直接子元素;3、closest(),用于返回被选元素的第一个祖先元素;4、contents(),用于返回被选元素的所有直接子元素;5、each(),用于为每个匹配元素执行函数;7、eq();8、find();9、first();10、is();11、last()等等。
2023-05-14

python遍历目录的方法小结

本文实例总结了python遍历目录的方法。分享给大家供大家参考,具体如下: 方法一使用递归:""" def WalkDir( dir, dir_callback = None, file_callback = None ):for item
2022-06-04

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录