结果集获取所有值

时间:2013-12-12 14:11:37

标签: java sql sqlite resultset

如何从所有列中获取所有值?

我试过这段代码:

 values.add(rs.getString(number));

其中number是rowcount。

但它只给了我最后一栏的所有值。

我需要从每一列中获取值,然后将其添加到arraylist中。

这是我的完整代码:

  // The column count starts from 1
  int number = 0;
  for ( i = 1; i < columnCount + 1; i++ ) {
  number++;
  ColumnNames = rsmd.getColumnName(i);

  ar.add(ColumnNames);
  System.out.println(ar);  
  }
 model.setColumnCount(columnCount);

  while ( rs.next() ) {
// values.add(rs.getString(ar.indexOf(i)));
values.add(rs.getString(number));
 System.out.println(values);



     model.addRow(new Object[] {value1,  value2, value3, value4});

  }

2 个答案:

答案 0 :(得分:14)

ResultsetMetaData也保存您的列数。下面的代码段将为结果集中的每一列填充一个Object数组。

API文档是您的朋友: http://docs.oracle.com/javase/7/docs/api/java/sql/ResultSet.html http://docs.oracle.com/javase/7/docs/api/java/sql/ResultSetMetaData.html

ResultSet resultSet = getResultSetFromSomewhere();
ResultSetMetaData resultSetMetaData = resultSet.getMetaData();
final int columnCount = resultSetMetaData.getColumnCount();

while (resultSet.next()) {
    Object[] values = new Object[columnCount];
    for (int i = 1; i <= columnCount; i++) {
        values[i - 1] = resultSet.getObject(i);
    }
    model.addRow(values);
}

答案 1 :(得分:7)

对于每个rs.next()

Object[] row = new Object[columnCount];
for (int i = 1; i <= columnCount; ++i) {
    row[i - 1] = rs.getString(i); // Or even rs.getObject()
}
model.addRow(row);