1

我有一个结果集ResultSet rs=stmt.executeQuery();我写了一个方法来打印查询结果如下

public void printResults(ResultSet rs) {
    // Getting column names
    int j = 1;
    while (true) {
        try {
    System.out.print(rs.getMetaData().getColumnName(j)+"    ");
    j++;
        }
        catch (Exception e) {
            System.out.println("\n");
            break;
        }
    }

    // Getting results
    while(rs.next()) {
        int i = 1;
        while (true) {
            try {
        System.out.print(rs.getString(i)+"  ");
        i++;
            }
            catch (Exception e) {
                System.out.println("\n");
                break;
            }
        }
    }
}

我的问题是:使用它是一个好主意try && catch......我觉得不是吗?会影响速度吗?有什么更好的方法?

Thank You

4

1 回答 1

2

您可以通过

 ResultSetMetaData meta= rs.getMetaData();
 int columnNum=meta.getColumnCount();

与此循环columnNum以获得结果以及列名。

for(int i=1;i<=columnNum;i++){
    System.out.print(meta.getColumnName(i)+" ");
}

//Get the data
while(rs.next){
  for(int i=1;i<=columnNum;i++){
    System.out.print(rs.getString(i)+" ");
  }
}
于 2013-11-12T16:32:12.423 回答