9

JDBC を介して MySQL にアクセスするクラスの「クエリ」メソッドを作成する必要があります。

メソッドへの入力パラメーターは完全な SQL コマンド (値を含む) であるため、フェッチする列の名前がわかりません。

一部の列は文字列で、一部は整数などです。

ArrayList<HashMap<String,Object>> このメソッドは、各 HashMap が 1 行である type の値を返す必要があり、ArrayList には結果のすべての行が含まれます。

ResultSet.getMetaData().getColumnCount()列数を取得し、現在の行からセルごとにフェッチすることを考えていますが、これが唯一の解決策ですか? より良いものはありますか?

4

1 に答える 1

15

誰かがそれを必要とする場合に備えて、ここにサンプルコードがあります。(コード内の「Con」は標準の JDBC 接続です)。

//query a full sql command
public static ArrayList<HashMap<String,Object>> 
rawQuery(String fullCommand) {
  try {

    //create statement
    Statement stm = null;
    stm = con.createStatement();

    //query
    ResultSet result = null;
    boolean returningRows = stm.execute(fullCommand);
    if (returningRows)
      result = stm.getResultSet();
    else
      return new ArrayList<HashMap<String,Object>>();

    //get metadata
    ResultSetMetaData meta = null;
    meta = result.getMetaData();

    //get column names
    int colCount = meta.getColumnCount();
    ArrayList<String> cols = new ArrayList<String>();
    for (int index=1; index<=Col_Count; index++)
      cols.add(meta.getColumnName(index));

    //fetch out rows
    ArrayList<HashMap<String,Object>> rows = 
    new ArrayList<HashMap<String,Object>>();

    while (result.next()) {
      HashMap<String,Object> row = new HashMap<String,Object>();
      for (String colName:cols) {
        Object val = Result.getObject(colName);
        row.put(colName,val);
      }
      rows.add(row);
    }

    //close statement
    stm.close();

    //pass back rows
    return tows;
  }
  catch (Exception ex) {
    System.out.print(ex.getMessage());
    return new ArrayList<HashMap<String,Object>>();
  }
}//raw_query
于 2012-08-06T10:48:50.007 に答える