ResultSet
2015-11-06 15:10
260 查看
表示数据库结果集的数据表,通常通过执行查询数据库的语句生成。
默认的
1 开始编号。为了获得最大的可移植性,应该按从左到右的顺序读取每行中的结果集列,每列只能读取一次。
对于获取方法,JDBC 驱动程序尝试将底层数据转换为在获取方法中指定的 Java 类型,并返回适当的 Java 值。JDBC 规范有一个表,显示允许的从 SQL 类型到
用作获取方法的输入的列名称不区分大小写。用列名称调用获取方法时,如果多个列具有这一名称,则返回第一个匹配列的值。在生成结果集的 SQL 查询中使用列名称时,将使用列名称选项。对于没有在查询中显式指定的列,最好使用列编号。如果使用列名称,则程序员应该注意保证名称唯一引用预期的列,这可以使用 SQL AS 子句确定。
在 JDBC 2.0 API(JavaTM 2 SDK 标准版 1.2 版)中,此接口添加了一组更新方法。关于获取方法参数的注释同样适用于更新方法的参数。
可以用以下两种方式使用更新方法:
更新当前行中的列值。在可滚动的
rs.updateRow(); // updates the row in the data source
[/code]
将列值插入到插入行中。可更新的
rs.updateInt(2,35); // updates the second column to be
rs.updateBoolean(3, true); // updates the third column to
rs.insertRow();
rs.moveToCurrentRow();
[/code]
当生成
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"); // rs will be scrollable, will not show changes made by others, // and will be updatable
ResultSet接口提供用于从当前行获取列值的 获取 方法(
getBoolean、
getLong等)。可以使用列的索引编号或列的名称获取值。一般情况下,使用列索引较为高效。列从
1 开始编号。为了获得最大的可移植性,应该按从左到右的顺序读取每行中的结果集列,每列只能读取一次。
对于获取方法,JDBC 驱动程序尝试将底层数据转换为在获取方法中指定的 Java 类型,并返回适当的 Java 值。JDBC 规范有一个表,显示允许的从 SQL 类型到
ResultSet获取方法所使用的 Java 类型的映射关系。
用作获取方法的输入的列名称不区分大小写。用列名称调用获取方法时,如果多个列具有这一名称,则返回第一个匹配列的值。在生成结果集的 SQL 查询中使用列名称时,将使用列名称选项。对于没有在查询中显式指定的列,最好使用列编号。如果使用列名称,则程序员应该注意保证名称唯一引用预期的列,这可以使用 SQL AS 子句确定。
在 JDBC 2.0 API(JavaTM 2 SDK 标准版 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 // [code]NAMEcolumn of row 5 to be
AINSWORTH
rs.updateRow(); // updates the row in the data source
[/code]
将列值插入到插入行中。可更新的
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 [code]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();
[/code]
当生成
ResultSet对象的
Statement对象关闭、重新执行或用来从多个结果的序列获取下一个结果时,
ResultSet对象将自动关闭。
ResultSet对象的列的编号、类型和属性由
ResultSet.getMetaData方法返回的
ResulSetMetaData对象提供。
相关文章推荐
- java.util.Date、java.sql.Date、java.sql.Time、java.sql.Timestamp小结
- 《 Java并发编程从入门到精通》 多线程之间交互:线程阀
- 【JAVA学习——eclipse编译器】
- Struts2文件上传
- 《Java并发编程从入门到精通》显示锁Lock和ReentrantLock
- Java的动态绑定与静态绑定
- java.io.IOException: Can't write xxx Can't read xxx
- 详解Java编程中if...else语句的嵌套写法
- 【Java基础学习】 详解Java的反射机制
- Java异常处理
- Java锁的种类以及辨析(四):可重入锁
- Java锁的种类以及辨析(三):阻塞锁
- SpringMVC和Struts2对比
- Java锁的种类以及辨析(二):自旋锁的其他种类
- 解决java错误“编码 GBK 的不可映射字符”
- SpringMVC与Struts2的对比
- java锁的种类以及辨析(一):自旋锁
- Java语言基础之内部类
- Unsupported major.minor version问题解决方法
- poi读取excel