深入理解 ResultSet(结果集)
创作时间:
作者:
@小白创作中心
深入理解 ResultSet(结果集)
引用
CSDN
1.
https://blog.csdn.net/keshi12354/article/details/146249102
ResultSet是Java数据库编程中一个关键的接口,用于存储SQL查询返回的结果集。在执行查询操作时,数据库会返回一系列的数据行,而ResultSet提供了一种遍历这些数据的方式。本文将深入探讨ResultSet的基本概念、常见操作及使用注意事项。
1. ResultSet 基本介绍
ResultSet代表数据库查询的结果表,它通常是通过执行SQL查询语句生成的。其主要特点如下:
- ResultSet对象保存一个光标指向其当前的数据行。
- 光标最初位于第一行之前,调用next()方法可以将光标移动到下一行。
- 当next()方法移动到超出ResultSet范围时,返回false,因此在while循环中可以使用它来遍历整个结果集。
这张类图展示了ResultSet接口的继承关系:
- ResultSet继承了AutoCloseable
- AutoCloseable接口提供了close()方法,用于在不再需要ResultSet时释放资源,防止资源泄漏。
- 这意味着ResultSet可以使用try-with-resources语法,自动关闭资源。
- ResultSet实现了Wrapper
- Wrapper接口提供了isWrapperFor(Class<?>)方法,用于检查当前对象是否是给定类的包装器。
- unwrap(Class
)方法可以获取底层对象的实例,通常用于JDBC驱动的自定义扩展。
2. ResultSet 的常见操作
2.1 通过 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 {
// 注册信息
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");
// 实例化
Class.forName(driver);
Connection connection = DriverManager.getConnection(url, user, password);
// 得到statement
Statement statement = connection.createStatement();
// 组织查询语句
String sql = "select id ,name, email from prima_key";
ResultSet resultSet = statement.executeQuery(sql);
// 遍历resultSet结果
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())来遍历查询结果。next()方法用于移动光标到下一行,并检查是否存在数据。
2.3 获取数据
ResultSet提供了多种方法来获取数据:
getInt(String columnLabel) / getInt(int columnIndex):获取整数类型数据。
getString(String columnLabel) / getString(int columnIndex):获取字符串类型数据。
getDouble(String columnLabel) / getDouble(int columnIndex):获取浮点数数据。

getBoolean(String columnLabel) / getBoolean(int columnIndex):获取布尔值。
3. ResultSet 的类型与特性
ResultSet在创建时可以指定类型,常见的类型包括:
- TYPE_FORWARD_ONLY(默认类型):光标只能向前移动。
- TYPE_SCROLL_INSENSITIVE:支持前后滚动,但不受数据库更新影响。
- TYPE_SCROLL_SENSITIVE:支持前后滚动,并且能感知数据库的更新。
Statement stmt = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
ResultSet rs = stmt.executeQuery("SELECT * FROM users");
4. 关闭 ResultSet
ResultSet在使用完成后,建议手动关闭以释放资源:
rs.close();
stmt.close();
conn.close();
5. 使用 ResultSet 更新数据
部分接口定义的方法:
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. 删除数据
if (rs.next()) {
rs.deleteRow();
}
7. ResultSet 使用注意事项
- 避免内存泄漏:使用完ResultSet及时关闭。
- 确保ResultSet游标类型:如果需要前后移动光标,使用TYPE_SCROLL_INSENSITIVE。
- 检查next()方法的返回值:确保遍历时不会越界。
- 获取数据时使用合适的方法:根据数据库数据类型选择getInt()、getString()等方法。
8.总结
ResultSet在Java数据库操作中扮演着重要角色,它提供了遍历和处理数据库查询结果的能力。通过合理选择ResultSet的类型和并发模式,并注意资源管理,可以提高数据库访问的效率和安全性。在开发过程中,掌握ResultSet的常见操作、类型和注意事项,将有助于更高效地管理数据库数据。
热门推荐
打卡新疆滑雪胜地感受雪场天花板 全国滑雪地图请收好→
秋冬温柔棕色系穿搭指南,优雅减龄又有气质,谁看了都心动
老年人主食的选择
蛋白质对老年人意义重大,建议老年人:这三种高蛋白食物该吃就吃
夜惊症频繁发作的处置方法是什么
夜惊症的5种治疗方法,从中药到认知行为疗法
创意热店和广告公司的区别
SSD基础科普:原理、寿命以及什么是连续与随机
高铁新城规划及案例分析
人们可能找到了《圣经·创世纪》中的罪恶之地索多玛
世界是先有蛋还是先有鸡?哲学给出的答案
秋招即将来临!应届生如何应对0工作经验问题?
上月福州新房价格环比下跌0.7%,政策对房地产市场的影响?
这些方法可以有效保护孩子上网安全
钾离子过低过高都不好!钾离子的功效、10大高钾食物吃这些
宝宝4个月还不会翻身怎么训练
简析《武侠乂》手游版——白玉虽瑕,难掩其光
正确掌握技巧 吹出更高的肺活量 肺部锻炼的方法有哪些
肺活量差的人怎么办 提升肺活量的有效锻炼方法解析
MIT蒋业明团队CRSus:新技术实现城市固体废物焚烧炉渣零浪费资源回收
股市外盘和内盘的区别是什么?这种差异如何影响市场趋势?
喝什么茶能抗氧化?七种茶叶的美白护肤功效大盘点
怀孕初期应该吃哪些海鱼?适合孕妇食用的海鱼有哪些?
“黄焖鸡米饭:简单美味的家庭聚餐首选”
CVT和DCT变速箱有什么区别
如何有效运用计划管理方法提高工作效率?
谷歌浏览器自动填充怎么关闭?Chrome浏览器自动填充禁用方法分享
生病小猫的饮食调理指南:从食材到注意事项全方位解析
藏在身边的“止咳猛将”,不是雪梨而是它,润肺止咳,别不懂吃!
如何正确卸载显卡驱动,保证电脑正常运转的技巧与步骤