ResultSet对象--next()方法

时间:2020-12-14 11:56:28

最近在修改别人代码bug的时候,程序中使用了ResultSet结果集,由于对该对象很少使用不免在百度中大肆的搜索一番,看到很多朋友提出的问题:

1.ResultSet对象是什么?

2.ResultSet是接口,为什么能有具体next()方法能调用返回结果?

3.ResultSet的isFirst()、isLast()为什么总是出错?

4.如何取得ResultSet集得第一条或者记录数?

等等。。。。

这些问题勾起了我的兴趣,便通过查阅JDK API,建了一个简单的工程后进行调试进行分析思考。

1.首先引用JDK  API中的相关说明:

public interface ResultSet

表示数据库结果集的数据表,通常通过执行查询数据库的语句生成。

ResultSet 对象具有指向其当前数据行的指针。最初,指针被置于第一行之前。next 方法将指针移动到下一行;因为该方法在 ResultSet 对象中没有下一行时返回 false,所以可以在 while 循环中使用它来迭代结果集。

默认的 ResultSet 对象不可更新,仅有一个向前移动的指针。因此,只能迭代它一次,并且只能按从第一行到最后一行的顺序进行。可以生成可滚动和/或可更新的 ResultSet 对象。以下代码片段(其中 con 为有效的 Connection 对象)演示了如何生成可滚动且不受其他更新影响的、可更新的结果集。请参阅 ResultSet 字段以了解其他选项。


       Statement stmt = con.createStatement(
                                      ResultSet.TYPE_SCROLL_INSENSITIVE,
                                      ResultSet.CONCUR_UPDATABLE);
       ResultSet rs = stmt.executeQuery("SELECT a, b FROM TABLE2");

ResultSet 接口提供用于从当前行检索列值的获取方法(getBoolean、getLong 等)。可以使用列的索引编号或列的名称检索值。一般情况下,使用列索引较为高效。列从 1 开始编号。为了获得最大的可移植性,应该按从左到右的顺序读取每行中的结果集列,而且每列只能读取一次。
对于获取方法,JDBC 驱动程序尝试将基础数据转换为在获取方法中指定的 Java 类型,并返回适当的 Java 值。JDBC 规范有一个表,显示允许的从 SQL 类型到供 ResultSet 获取方法使用的 Java 类型的映射关系。


用作获取方法的输入的列名称不区分大小写。用列名称调用获取方法时,如果多个列具有这一名称,则返回第一个匹配列的值。列名称选项在生成结果集的 SQL 查询中使用列名称时使用。对于没有在查询中显式命名的列,最好使用列编号。如果使用列名称,程序员无法保证名称实际所指的就是预期的列。

在 JDBC 2.0 API (JDK 1.2) 中,此接口添加了一组更新方法。关于获取方法参数的注释同样适用于更新方法的参数。

可以用以下两种方式使用更新方法:

更新当前行中的列值。在可滚动的 ResultSet 对象中,可以向前和向后移动指针,将其置于绝对位置或相对于当前行的位置。以下代码片段更新 ResultSet 对象 rs 的第五行中的 NAME 列,然后使用方法 updateRow 更新用于派生 rs 的数据源表。

       rs.absolute(5); // moves the cursor to the fifth row of rs
       rs.updateString("NAME", "AINSWORTH"); // updates the
       // NAME column of row 5 to be AINSWORTH
       rs.updateRow(); // updates the row in the data source

将列值插入到插入行中。可更新的 ResultSet 对象具有一个与其关联的特殊行,该行用作构建要插入的行的暂存区域 (staging area)。以下代码片段将指针移动到插入行,构建一个三列的行,并使用方法 insertRow 将其插入到 rs 和数据源表中。

       rs.moveToInsertRow(); // moves cursor to the insert row
       rs.updateString(1, "AINSWORTH"); // updates the
       // first column of the insert row to be AINSWORTH
       rs.updateInt(2,35); // updates the second column to be 35
       rs.updateBoolean(3, true); // updates the third column to true
       rs.insertRow();
       rs.moveToCurrentRow();

当生成 ResultSet 对象的 Statement 对象关闭、重新执行或用来从多个结果的序列检索下一个结果时,ResultSet 对象会自动关闭。

ResultSet 对象的列的编号、类型和属性由 ResultSet.getMetaData 方法返回的 ResulSetMetaData 对象提供。

2.测试以及调试:

查看了JDK  API帮助文档之后,与ResultSet 相关的都是接口,那么接口中的方法又是在什么类中实现被调用的呢?带着这个问题我经过在JDK源码中搜索,没有结果并发现JDK中的java.sql.*中提供的都是接口而未提供实现。因此觉得很奇怪。。。。。

于是,创建了一个简单的工程编写测试类并导入ojdbc14.jar和JDK源码进行调试。原来JDK中接口的实现类都是在ojdbc14.jar工具包中实现的,很可惜的是ojdbc14.jar中代码无法看到源码,否则可以看到具体方法的实现内容了。

以下是ResultSet在oracle driver中实现类继承的关系图:

ResultSet对象--next()方法

其他的接口应该是类似的情况,希望能给朋友们减少一些疑问。

 

以上若有误请指正,谢谢!

在编程中寻找快乐,在快乐中*编程!