您好,登錄后才能下訂單哦!
這篇文章主要介紹“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實體集合。
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(); } }
關于“ResultSet的遍歷方法有哪些”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。