溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

ResultSet的遍歷方法有哪些

發(fā)布時(shí)間:2023-02-28 11:10:19 來(lái)源:億速云 閱讀:198 作者:iii 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要介紹“ResultSet的遍歷方法有哪些”的相關(guān)知識(shí),小編通過(guò)實(shí)際案例向大家展示操作過(guò)程,操作方法簡(jiǎn)單快捷,實(shí)用性強(qiáng),希望這篇“ResultSet的遍歷方法有哪些”文章能幫助大家解決問(wèn)題。

    ResultSet的遍歷方法

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

    第一:直接迭代

    1.DQL代碼

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

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

    這個(gè)rs保存了查詢(xún)返回的結(jié)果集,并沒(méi)有讀取出來(lái)呢,究竟怎么讀呢?首先讓我們了解一下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()方法一開(kāi)始是處于第一行之前,即beforeFirst,第一次使用next()就將指針指向返回結(jié)果集的第一行。每使用一次next(),指針就指向下一行。

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

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

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

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

    3.寫(xiě)代碼讀取ResultSet

    3.1 讀取方法1 – 通過(guò)索引來(lái)遍歷讀取

    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 – 通過(guò)字段名稱(chēng)來(lái)讀取

    強(qiáng)調(diào)一下,這個(gè)傳入的字段名稱(chēng)可以不區(qū)分大小寫(xiě),因?yàn)樵?a title="mysql" target="_blank" href="http://www.kemok4.com/mysql/">mysql中就是不區(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)用三方工具類(lèi)

    直接使用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。

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

    ResultSet的遍歷方法有哪些

    用循環(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查詢(xún)數(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();
    
        }
    }

    關(guān)于“ResultSet的遍歷方法有哪些”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí),可以關(guān)注億速云行業(yè)資訊頻道,小編每天都會(huì)為大家更新不同的知識(shí)點(diǎn)。

    向AI問(wèn)一下細(xì)節(jié)

    免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

    AI