动态获取ResultSet列和值

Mic*_*l A 1 java sql db2 ibm-midrange

我在AS400表上运行SQL查询.

我事先不知道我在SQL中提取的列名.

在我的ResultSet中,我需要:

  1. 获取结果集列(结果记录的MetaData - 一次).

  2. 对于集合中的每个记录,获取列的值.

我怎样才能做到这一点?

bw_*_*ezi 5

从ConnectionSet中的Connection.getMetaData()和ResultSetMetaData中检索DataBaseMetaData.

一些示例java代码剪切可能会帮助您:

Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery( "SELECT * FROM MY_TABLE" );
ResultSetMetaData rsmd = rs.getMetaData();
int numberOfColumns = rsmd.getColumnCount();
/*if you need the column names...*/ 
//for( int i = 1; i <= numberOfColumns ) {
//    rsmd.getColumnName( i );
//}
List<Object[]> result = new ArrayList<Object[]>();
while( rs.next() ) {
    Object[] values = new Object[ numberOfColumns ];
    for( int index = 0; index < numberOfColumns; ) {
        values[ index ] = rs.getObject( ++index );
    }
    result.add( values );
}
Run Code Online (Sandbox Code Playgroud)