關(guān)于ResultSet(結(jié)果集)用法詳解
在 Java 數(shù)據(jù)庫(kù)編程中,ResultSet 是一個(gè)關(guān)鍵的接口,它用于存儲(chǔ) SQL 查詢(xún)返回的結(jié)果集。在執(zhí)行查詢(xún)操作時(shí),數(shù)據(jù)庫(kù)會(huì)返回一系列的數(shù)據(jù)行,而 ResultSet 提供了一種遍歷這些數(shù)據(jù)的方式。
1. ResultSet 基本介紹
ResultSet 代表數(shù)據(jù)庫(kù)查詢(xún)的結(jié)果表,它通常是通過(guò)執(zhí)行 SQL 查詢(xún)語(yǔ)句生成的。其主要特點(diǎn)如下:
ResultSet對(duì)象保存一個(gè)光標(biāo)指向其當(dāng)前的數(shù)據(jù)行。- 光標(biāo)最初位于第一行之前,調(diào)用
next()方法可以將光標(biāo)移動(dòng)到下一行。 - 當(dāng)
next()方法移動(dòng)到超出ResultSet范圍時(shí),返回false,因此在while循環(huán)中可以使用它來(lái)遍歷整個(gè)結(jié)果集。

這張類(lèi)圖展示了 ResultSet 接口的繼承關(guān)系:
1.ResultSet 繼承了 AutoCloseable
AutoCloseable接口提供了close()方法,用于在不再需要ResultSet時(shí)釋放資源,防止資源泄漏。- 這意味著
ResultSet可以使用 try-with-resources 語(yǔ)法,自動(dòng)關(guān)閉資源。
2.ResultSet 實(shí)現(xiàn)了 Wrapper
Wrapper接口提供了isWrapperFor(Class<?>)方法,用于檢查當(dāng)前對(duì)象是否是給定類(lèi)的包裝器。unwrap(Class<T>)方法可以獲取底層對(duì)象的實(shí)例,通常用于 JDBC 驅(qū)動(dòng)的自定義擴(kuò)展。
2. ResultSet 的常見(jiàn)操作
2.1 通過(guò) JDBC 獲取 ResultSet
package JDBC;
import java.io.FileInputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.Properties;
public class ResultSet_ {
public static void main(String[] args) throws Exception {
// 注冊(cè)信息
Properties properties = new Properties();
properties.load(new FileInputStream("src\\JDBC\\mysql.properties"));
String url = (String) properties.get("url");
String user =(String) properties.get("user");
String password =(String) properties.get("password");
String driver =(String) properties.get("driver");
// 實(shí)例化
Class.forName(driver);
Connection connection = DriverManager.getConnection(url, user, password);
// 得到statement
Statement statement = connection.createStatement();
// 組織查詢(xún)語(yǔ)句
String sql = "select id ,name, email from prima_key";
ResultSet resultSet = statement.executeQuery(sql);
// 遍歷resultSet結(jié)果
while (resultSet.next()) {
int anInt = resultSet.getInt(1);
String name =resultSet.getString(2);
String email = resultSet.getString(3);
System.out.println(anInt + " " + name + " " + email);
}
System.out.println(connection);
}
}2.2 遍歷 ResultSet
在上面的示例中,我們使用 while (rs.next()) 來(lái)遍歷查詢(xún)結(jié)果。
next() 方法用于移動(dòng)光標(biāo)到下一行,并檢查是否存在數(shù)據(jù)。
2.3 獲取數(shù)據(jù)


ResultSet 提供了多種方法來(lái)獲取數(shù)據(jù):
getInt(String columnLabel) / getInt(int columnIndex):獲取整數(shù)類(lèi)型數(shù)據(jù)。 getString(String columnLabel) / getString(int columnIndex):獲取字符串類(lèi)型數(shù)據(jù)。 getDouble(String columnLabel) / getDouble(int columnIndex):獲取浮點(diǎn)數(shù)數(shù)據(jù)。 getBoolean(String columnLabel) / getBoolean(int columnIndex):獲取布爾值。
3. ResultSet 的類(lèi)型與特性


ResultSet 在創(chuàng)建時(shí)可以指定類(lèi)型,常見(jiàn)的類(lèi)型包括:
TYPE_FORWARD_ONLY(默認(rèn)類(lèi)型):光標(biāo)只能向前移動(dòng)。TYPE_SCROLL_INSENSITIVE:支持前后滾動(dòng),但不受數(shù)據(jù)庫(kù)更新影響。TYPE_SCROLL_SENSITIVE:支持前后滾動(dòng),并且能感知數(shù)據(jù)庫(kù)的更新。
Statement stmt = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
ResultSet rs = stmt.executeQuery("SELECT * FROM users");4. 關(guān)閉 ResultSet
ResultSet 在使用完成后,建議手動(dòng)關(guān)閉以釋放資源:

rs.close(); stmt.close(); conn.close();
5. 使用 ResultSet 更新數(shù)據(jù)
部分接口定義的方法:

Statement stmt = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_UPDATABLE);
ResultSet rs = stmt.executeQuery("SELECT id, name FROM users WHERE id = 1");
if (rs.next()) {
rs.updateString("name", "NewName");
rs.updateRow();
}6. 刪除數(shù)據(jù)

if (rs.next()) {
rs.deleteRow();
}7. ResultSet 使用注意事項(xiàng)
- 避免內(nèi)存泄漏:使用完
ResultSet及時(shí)關(guān)閉。 - 確保 ResultSet 游標(biāo)類(lèi)型:如果需要前后移動(dòng)光標(biāo),使用
TYPE_SCROLL_INSENSITIVE。 - 檢查 next() 方法的返回值:確保遍歷時(shí)不會(huì)越界。
- 獲取數(shù)據(jù)時(shí)使用合適的方法:根據(jù)數(shù)據(jù)庫(kù)數(shù)據(jù)類(lèi)型選擇
getInt()、getString()等方法。
8.總結(jié)
ResultSet 在 Java 數(shù)據(jù)庫(kù)操作中扮演著重要角色,它提供了遍歷和處理數(shù)據(jù)庫(kù)查詢(xún)結(jié)果的能力。
通過(guò)合理選擇 ResultSet 的類(lèi)型和并發(fā)模式,并注意資源管理,可以提高數(shù)據(jù)庫(kù)訪問(wèn)的效率和安全性。
在開(kāi)發(fā)過(guò)程中,掌握 ResultSet 的常見(jiàn)操作、類(lèi)型和注意事項(xiàng),將有助于更高效地管理數(shù)據(jù)庫(kù)數(shù)據(jù)。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
java使用jacob實(shí)現(xiàn)word轉(zhuǎn)pdf
這篇文章主要為大家詳細(xì)介紹了java使用jacob實(shí)現(xiàn)word轉(zhuǎn)pdf,通過(guò)調(diào)用模板文件,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12
collection集合體系與并發(fā)修改異常的解決方法
今天小編就為大家分享一篇關(guān)于collection集合體系與并發(fā)修改異常的解決方法,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-03-03
Springboot+SpringSecurity實(shí)現(xiàn)圖片驗(yàn)證碼登錄的示例
本文主要介紹了Springboot+SpringSecurity實(shí)現(xiàn)圖片驗(yàn)證碼登錄的示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04
用Java打造簡(jiǎn)易計(jì)算器的實(shí)現(xiàn)步驟
這篇文章主要介紹了如何設(shè)計(jì)和實(shí)現(xiàn)一個(gè)簡(jiǎn)單的Java命令行計(jì)算器程序,該程序能夠執(zhí)行基本的數(shù)學(xué)運(yùn)算(加、減、乘、除),文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2025-01-01
hutool實(shí)戰(zhàn):IoUtil 流操作工具類(lèi)(將內(nèi)容寫(xiě)到流中)
這篇文章主要介紹了Go語(yǔ)言的io.ioutil標(biāo)準(zhǔn)庫(kù)使用,是Golang入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下,如果能給你帶來(lái)幫助,請(qǐng)多多關(guān)注腳本之家的其他內(nèi)容2021-06-06
JAVA SE包裝類(lèi)和泛型詳細(xì)介紹及說(shuō)明方法
這篇文章主要介紹了JAVA SE包裝類(lèi)和泛型的相關(guān)資料,包括基本數(shù)據(jù)類(lèi)型與包裝類(lèi)的對(duì)應(yīng)關(guān)系,以及裝箱和拆箱的概念,并重點(diǎn)講解了自動(dòng)裝箱和自動(dòng)拆箱的機(jī)制,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2025-03-03

