Java.sql.ResultSet 接口

Java.sql.ResultSet 接口

一. 结果集ResultSet
       ResultSet (结果集)是数据中查询结果返回的一种对象,可以说结果集是一个存储查询结果的对象,但是结果集并不仅仅具有存储的功能,他同时还具有操纵数据的功能,可能完成对数据的更新等。
       ResultSet读取数据的方法主要是getXXX(),他的参数可以是整型或者列名(数据表列名),整形表示取得第几列(是从1开始的),该方法返回的返回值对应的XXX类型的值。如果对应列名是空值,如果XXX是对象类型,则返回XXX型的空值,如果XXX是数字类型,如Float等则返回0,boolean类型则返回false。XXX可以代表的类型有: 基本的数据类型如整型(int),布尔型(Boolean),浮点型(Float,Double)等,比特型(byte),还包括一些特殊的类型,如:日期类型(Date)、时间戳(Timestamp)、时间(Time)、大数型 (BigDecimal和BigInteger等)等。
       使用getString()可以返回所有的列的值,不过返回的都是字符串类型的。还可以使用getArray(int colindex/String columnname),通过这个方法获得当前行中,colindex所在列的元素组成的对象的数组。使用 getAsciiStream(intcolindex/String colname)可以获得该列对应的当前行的ascii流。也就是说所有的getXXX方法都是对当前行进行操作。
       ResultSet从其使用的特点上 可以分为四类,这四类的结果集的所具备的特点都是和Statement语句的创建有关,因为结果集是通过Statement语句执行后产生的,结果集的特点完全决定于Statement。在Statement创建时包括三种类型。
       1.首先是无参数类型的,它对应的就是下面要介绍的基本的ResultSet对应的Statement。下面的代码中用到的Connection并没有对其初始化,变量conn代 表的就是Connection对应的对象,SqlStr代表的是响应的SQL语句。最基本的ResultSet是因为它起到的作用就是完成了查询结果的存储功能,而且只能读取一次,不能够来回的滚动读取。这种结果集的创建方式如下:

Statement st = conn.CreateStatement();
ResultSet rs = Statement.excuteQuery(sqlStr);

由于这种结果集不支持滚动的读取功能,所以如果获得这样一个结果集,只能使用它里面的next()方法,逐个的读去数据.
2、可滚动的ResultSet类型。
    可滚动类型支持前后滚动取得纪录next()、previous(),回到第一行first(),同时还支持要取的ResultSet中的第几行 absolute(int n),以及移动到相对当前行的第几行relative(int n),要实现这样的ResultSet在创建Statement时用如下的方法:
   
*Statement st=conn.createStatement(int resultSetType, int resultSetConcurrency);

ResultSet rs = st.executeQuery(sqlStr);*
其中两个参数的意义是:
resultSetType是设置ResultSet对象的类型标示可滚动,或者是不可滚动。取值如下:

|

项目价格
ResultSet.TYPE_FORWARD_ONLY只能向前滚动(这是默认值)
ResultSet.TYPE_SCROLL_INSENSITIVE这两个方法都能够实现任意的前后滚动,使用各种移动的ResultSet指针的方法。二者的区别在于前者对于修改不敏感,而后者对于修改敏感。
Result.TYPE_SCROLL_SENSITIVE
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值