Result的方法
ResultSet遍歷兩種方法,第一,直接迭代,第二,用第三方工具類
第一:直接迭代:
1.DQL代碼
不同于前面的DML過程的是,將原來的sql語句改成DQL,并且調(diào)用statement的executeQuery() 方法執(zhí)行查詢,返回結(jié)果使用ResultSet 進(jìn)行接收。
String sql = “select * from student”;
ResultSet rs = stmt.executeQuery(sql);
這個rs保存了查詢返回的結(jié)果集,并沒有讀取出來呢,究竟怎么讀呢?首先讓我們了解一下ResultSet
2.ResultSet 的功能
這個ResultSet 究竟是個什么鬼呢?查看API文檔之后,總結(jié)如下:
2.1 ResultSet 對象具有指向其當(dāng)前數(shù)據(jù)行的光標(biāo)。 最初,光標(biāo)被置于第一行之前。調(diào)用 next() 方法將光標(biāo)移動到下一行;next()方法一開始是處于第一行之前,即beforeFirst,第一次使用next()就將指針指向返回結(jié)果集的第一行。每使用一次next(),指針就指向下一行。
因為該方法在 ResultSet 對象沒有下一行時返回 false, 所以可以在 while 循環(huán)中使用它來迭代結(jié)果集,調(diào)用getXXX(int fieldIndex)/getXXX(String columnName)方法獲取字段值。2.2 ResultSet 接口提供用于從當(dāng)前行獲取列值的獲取方法(getBoolean、getLong 等)。
可以使用列的索引編號或列的名稱獲取值。一般情況下,使用列索引較為高效。列從 1開始編號。為了獲得最大的可移植性,應(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)一下,這個傳入的字段名稱可以不區(qū)分大小寫,因為在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)用三方工具類
直接使用BeanHandler ,就可以簡化大部分代碼
BeanHandler bh =new BeanHandler(Student.class);
//rs是ResultSet得到的從返回集合
Student li = bh.handle(rs);
BeanHandler是返回一個實體對象,BeanListHandler是返回一個list實體集合,MapHandler是返回不確定的單個實體對象,MapListHandler是返回不確定的list實體集合。
總結(jié)
- 上一篇: docker nginx配置_docke
- 下一篇: 综合类新闻(APP)