列数

如何获取ResultSet的行数和列数

不羁的心 提交于 2019-12-02 14:22:47
当我们执行数据库查询返回一个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