如何获取RsultSet的行数和列数.doc

  1. 1、本文档共3页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
如何获取RsultSet的行数和列数

HYPERLINK /kane1990/archive/2011/12/25/2300961.html 如何获取ResultSet的行数和列数 当我们执行数据库查询返回一个ResultSet的时候,很多情况下我们需要知道这个ResultSet的大小,即它的行数和列数。我们知道它的列数可以通过resultSet.getMetaData().getColumnCount()很容易地得到,然而,java API没有提供直接访问ResultSet行数的接口。 这个时候,有三个办法可以解决: 1.改用select count语句,然后直接从ResultSet里面获取结果: try { Statement statement = connection.createStatement(); ResultSet resultSet = statement.executeQuery(select count(*) as rowCount from tableName); resultSet.next(); int rowCount = resultSet.getInt(rowCount); } catch (Exception e) { // TODO: handle exception e.printStackTrace(); } 但是,我们执行数据库查询不光要知道结果的行数,往往接下来还要用到查询结果。如果用此方法,还需要再执行一次select语句,才能得到想要的结果集,这样,就多了一次数据库查询,大大降低了执行速度。 2.遍历Resultset,用一个变量记录行数。代码如下: int count = 0; try { while(resultSet.next()){ count = count + 1; } } catch (SQLException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } 这样获取的count值就是结果集的行数。然而,这种方法同第一种方法的问题一样,不能再使用结果集了。因为这时候指针已经移动到结果集的外面了,不再指向任何记录。 3.知道了第二种方法中问题的原因,我们就知道如何更好地解决这个问题了。第二种方法的问题在于返回的结果集中的指针不能自由移动,幸好java为我们提供了选择,可以让我们创建指针可以自由移动的结果集,所需要做的只有一件事,就是在创建Statement的时候,加上两个参数: try { //Statement statement = connection.createStatement(); Statement statement = connection.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE); ResultSet resultSet = statement.executeQuery(select * from + tableName); } catch (Exception e) { // TODO: handle exception e.printStackTrace(); } 这样获得的结果集,指针就可以在其中自由移动。然后,就可以用如下方法获取结果集的行数: int rowCount = 0; try { resultSet.last(); rowCount = resultSet.getRow(); } catch (Exception e) { // TODO: handle exception e.printStackTrace(); } 其中resultSet.last()就是将指针移动到结果集的最后一条记录;然后用resultSet.getRow()获取指针当前所在的行号(从1开始)

文档评论(0)

ybcm963 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档