解讀ResultSet的遍歷方法
ResultSet的遍歷方法
ResultSet遍歷兩種方法,第一,直接迭代,第二,用第三方工具類
第一:直接迭代
1.DQL代碼
不同于前面的DML過(guò)程的是,將原來(lái)的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é)果集,并沒(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)或列的名稱獲取值。一般情況下,使用列索引較為高效。列從 1開(kāi)始編號(hào)。為了獲得最大的可移植性,應(yīng)該按從左到右的順序讀取每行中的結(jié)果集列, 每列只能讀取一次。
2.3 用作獲取方法的輸入的列名稱不區(qū)分大小寫
3.寫代碼讀取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ò)字段名稱來(lái)讀取
強(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。
剛開(kāi)始游標(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中BufferedReader和BufferedWriter使用方式
這篇文章主要介紹了Java中BufferedReader和BufferedWriter使用方式,F(xiàn)ileWriter?類從?OutputStreamWriter?類繼承而來(lái),BufferedReader?類從字符輸入流中讀取文本并緩沖字符,以便有效地讀取字符,數(shù)組和行2022-06-06
SpringBoot實(shí)現(xiàn)識(shí)別圖片中的身份證號(hào)與營(yíng)業(yè)執(zhí)照信息
這篇文章主要為大家詳細(xì)介紹了SpringBoot如何實(shí)現(xiàn)識(shí)別圖片中的身份證號(hào)與營(yíng)業(yè)執(zhí)照信息,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2024-01-01
IDEA的Swing可視化插件JFormDesigner詳解
JFormDesigner是一個(gè)專業(yè)的軟件應(yīng)用程序,專門用于幫助您開(kāi)發(fā)Java?Swing用戶界面,而無(wú)需具備編程技能。它可作為獨(dú)立實(shí)用程序使用,也可以將其用作各種IDE的插件,本文給大家介紹idea?Swing可視化插件,感興趣的朋友一起看看吧2022-06-06
深入理解Java中的構(gòu)造函數(shù)引用和方法引用
java構(gòu)造函數(shù),也叫構(gòu)造方法,是java中一種特殊的函數(shù)。函數(shù)名與相同,無(wú)返回值。方法引用是用來(lái)直接訪問(wèn)類或者實(shí)例的已經(jīng)存在的方法或者構(gòu)造方法。下面我們來(lái)詳細(xì)了解一下它們吧2019-06-06
Java權(quán)重隨機(jī)的實(shí)現(xiàn)方法
這篇文章主要介紹了Java權(quán)重隨機(jī)的實(shí)現(xiàn)方法,實(shí)例分析了權(quán)重隨機(jī)算法的原理與完整實(shí)現(xiàn)方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-01-01
SpringBoot原理之自動(dòng)配置機(jī)制詳解
Springboot遵循“約定優(yōu)于配置”的原則,使用注解對(duì)一些常規(guī)的配置項(xiàng)做默認(rèn)配置,減少或不使用xml配置,讓你的項(xiàng)目快速運(yùn)行起來(lái),下面這篇文章主要給大家介紹了關(guān)于SpringBoot原理之自動(dòng)配置機(jī)制的相關(guān)資料,需要的朋友可以參考下2021-11-11
Hadoop之NameNode Federation圖文詳解
今天小編就為大家分享一篇關(guān)于Hadoop之NameNode Federation圖文詳解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-01-01
SpringBoot為啥不用配置啟動(dòng)類的實(shí)現(xiàn)
這篇文章主要介紹了SpringBoot為啥不用配置啟動(dòng)類的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
SpringBoot頂層接口實(shí)現(xiàn)類注入項(xiàng)目的方法示例
本文主要介紹了SpringBoot頂層接口實(shí)現(xiàn)類注入項(xiàng)目的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-06-06
java應(yīng)用cpu占用過(guò)高問(wèn)題分析及解決方法
這篇文章主要介紹了java應(yīng)用cpu占用過(guò)高問(wèn)題分析及解決方法,具有一定參考價(jià)值,需要的朋友可以參考下。2017-09-09

