欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解讀ResultSet的遍歷方法

 更新時(shí)間:2023年02月28日 09:09:24   作者:愛吃牛肉的大老虎  
這篇文章主要介紹了ResultSet的遍歷方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

ResultSet的遍歷方法

ResultSet遍歷兩種方法,第一,直接迭代,第二,用第三方工具類

第一:直接迭代

1.DQL代碼

不同于前面的DML過程的是,將原來的sql語(yǔ)句改成DQL,并且調(diào)用statement的executeQuery() 方法執(zhí)行查詢,返回結(jié)果使用ResultSet 進(jìn)行接收。

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

這個(gè)rs保存了查詢返回的結(jié)果集,并沒有讀取出來呢,究竟怎么讀呢?首先讓我們了解一下ResultSet

2.ResultSet 的功能

這個(gè)ResultSet 究竟是個(gè)什么鬼呢?查看API文檔之后,總結(jié)如下:

2.1 ResultSet 對(duì)象具有指向其當(dāng)前數(shù)據(jù)行的光標(biāo)。 最初,光標(biāo)被置于第一行之前。調(diào)用 next() 方法將光標(biāo)移動(dòng)到下一行;next()方法一開始是處于第一行之前,即beforeFirst,第一次使用next()就將指針指向返回結(jié)果集的第一行。每使用一次next(),指針就指向下一行。

因?yàn)樵摲椒ㄔ?ResultSet 對(duì)象沒有下一行時(shí)返回 false, 所以可以在 while 循環(huán)中使用它來迭代結(jié)果集,調(diào)用getXXX(int fieldIndex)/getXXX(String columnName)方法獲取字段值。

2.2 ResultSet 接口提供用于從當(dāng)前行獲取列值的獲取方法(getBoolean、getLong 等)。

可以使用列的索引編號(hào)或列的名稱獲取值。一般情況下,使用列索引較為高效。列從 1開始編號(hào)。為了獲得最大的可移植性,應(yīng)該按從左到右的順序讀取每行中的結(jié)果集列, 每列只能讀取一次。

2.3 用作獲取方法的輸入的列名稱不區(qū)分大小寫

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 – 通過字段名稱來讀取

強(qiáng)調(diào)一下,這個(gè)傳入的字段名稱可以不區(qū)分大小寫,因?yàn)樵趍ysql中就是不區(qū)分的

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);
? ? }

第二:調(diào)用三方工具類

直接使用BeanHandler<T> ,就可以簡(jiǎn)化大部分代碼

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

BeanHandler<T>是返回一個(gè)實(shí)體對(duì)象,BeanListHandler<T>是返回一個(gè)list實(shí)體集合,MapHandler是返回不確定的單個(gè)實(shí)體對(duì)象,MapListHandler是返回不確定的list實(shí)體集合。

ResuSet遍歷結(jié)果集

先找到位置,再獲取數(shù)據(jù)

  • next():作用是使游標(biāo)下移,返回的是布爾型,判斷當(dāng)前行是否是最后一行末尾(是否有數(shù)據(jù)),如果是,返回false,反之則返回ture。

剛開始游標(biāo)的位置:

在這里插入圖片描述

用循環(huán)判斷游標(biāo)是否在最后一行:

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查詢數(shù)據(jù)庫(kù)信息

package cn.cast.jdbc;

import java.sql.*;

public class JdbcDemo4 {
    public static void main(String[] args) throws ClassNotFoundException, SQLException {
     //注冊(cè)驅(qū)動(dòng)
     Class.forName("com.mysql.cj.jdbc.Driver");
     //獲取數(shù)據(jù)庫(kù)連接對(duì)象
      Connection conn= DriverManager.getConnection("jdbc:mysql:///stu?serverTimezone=GMT","root","root");
      //定義sql語(yǔ)句
        String sql="select * from ss";
        //獲取執(zhí)行sql的對(duì)象
        Statement stmt=conn.createStatement();
        //執(zhí)行sql
        ResultSet rs=stmt.executeQuery(sql);
        //處理結(jié)果(以next返回值判斷是否在最后一行,然后獲取數(shù)據(jù))
        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();

    }
}

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java 線程池ExecutorService詳解及實(shí)例代碼

    Java 線程池ExecutorService詳解及實(shí)例代碼

    這篇文章主要介紹了Java 線程池ExecutorService詳解及實(shí)例代碼的相關(guān)資料,線程池減少在創(chuàng)建和銷毀線程上所花的時(shí)間以及系統(tǒng)資源的開銷.如果不使用線程池,有可能造成系統(tǒng)創(chuàng)建大量線程而導(dǎo)致消耗系統(tǒng)內(nèi)存以及”過度切換“
    2016-11-11
  • java讀取resources文件詳解及實(shí)現(xiàn)代碼

    java讀取resources文件詳解及實(shí)現(xiàn)代碼

    這篇文章主要介紹了java讀取resources文件詳解及實(shí)現(xiàn)代碼的相關(guān)資料,在開發(fā)項(xiàng)目的時(shí)候經(jīng)常會(huì)遇到讀取文件夾里面的內(nèi)容,需要的朋友可以參考下
    2017-07-07
  • Spring中的事務(wù)管理如何配置

    Spring中的事務(wù)管理如何配置

    這篇文章主要介紹了spring中的事務(wù)管理如何配置,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • 通過volatile驗(yàn)證線程之間的可見性

    通過volatile驗(yàn)證線程之間的可見性

    這篇文章主要介紹了通過volatile驗(yàn)證線程之間的可見性,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • java學(xué)習(xí)之路_篇超好的文章

    java學(xué)習(xí)之路_篇超好的文章

    一篇超好的文章!就看你有沒耐心看!java學(xué)習(xí)之路!
    2008-10-10
  • IDEA中Translation使用及問題解決

    IDEA中Translation使用及問題解決

    本文主要介紹了IDEA中Translation使用及問題解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • 如何把idea中的項(xiàng)目導(dǎo)入github倉(cāng)庫(kù)中(圖文詳解)

    如何把idea中的項(xiàng)目導(dǎo)入github倉(cāng)庫(kù)中(圖文詳解)

    這篇文章主要介紹了如何把idea中的項(xiàng)目導(dǎo)入github倉(cāng)庫(kù)中,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-07-07
  • SpringBoot讀取外部配置文件的方法

    SpringBoot讀取外部配置文件的方法

    這篇文章主要介紹了SpringBoot讀取外部配置文件的方法,以端口配置為例,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-02-02
  • 全解史上最快的JOSN解析庫(kù)alibaba Fastjson

    全解史上最快的JOSN解析庫(kù)alibaba Fastjson

    這篇文章主要介紹了史上最快的JOSN解析庫(kù)alibaba Fastjson,對(duì)FastJson感興趣的同學(xué),一定要看一下
    2021-04-04
  • Springboot2 集成 druid 加密數(shù)據(jù)庫(kù)密碼的配置方法

    Springboot2 集成 druid 加密數(shù)據(jù)庫(kù)密碼的配置方法

    這篇文章給大家介紹Springboot2 集成 druid 加密數(shù)據(jù)庫(kù)密碼的配置方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2021-07-07

最新評(píng)論