質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.34%

  • Java

    14391questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

ResultSetをまとめて(?)取得する

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 2,716

Java 超初心者です。

DBに接続し、ブラウザ上にデータベースのデータを検索し表示するプログラムです。
A,B,C三つの名称があるテーブルがあります。
ブラウザ上の検索画面でA,B,Cの表示列を指定出来るようにしたいです。
処理をサーブレット、表示をjsp、DB接続するjavaファイルを使います。
チェックボックスでABC全てにチェックを入れると全てうまくいきます。
しかしどれか一つでもチェックを外すとエラーとなります。
デバック等で原因もその場所も分かっています。しかしその修正の仕方がイマイチ分からないから教えてほしいという質問です。
DB接続するファイルでの問題の箇所です。
サーブレットでSQL文を作ってここに渡してます。

ArrayList<String[]>array = new ArrayList<String[]>();
connect con = null;
try{
con = Driver Manager.getConnection(〇〇〇);
ResultSet rs = statement.executeQuery(sql);
While (rs.next()){
String A = rs.getString("a");
String B = rs.getString("b");
String C = rs.getString("c");
array.add(new String[]{A,B,C});
...

チェックボックスでABCを選択するここに送られうまくいくのですが一つでも外す、例えばBCなど。するとAが存在しないため↑のtryの中身に行かずエラーになります。逆に
String A = rs.getString("a");
String C = rs.getString("c");
とするとACがチェックされた時のみうまくいきます。
どうこのtryの中身を変えれば良いですか?
個人的に調べた結果、http://blog.livedoor.jp/chika174/archives/866146.html
このあたりを使うのかなあ…と思ってるんですが

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

checkベストアンサー

0

画面側のチェックボックスの状態を取得できるようにしてやるのが個人的には一番気持ちいいやり方です。
javaだけでやるなら、下みたいにやると思います。

ArrayList<String[]> array = new ArrayList<String[]>();
connect con = null;

String[] columnNames = {"a", "b", "c"};                // 列名一覧
Map<String, bool> columnExists = new HashMap<>();    // <列名, 存在フラグ>
for(int i = 0; i < columnNames.length; i++){
    // すべての列を"存在しない"で初期化
    columnExists.put(columnNames[i], false);
}

// データ準備
con = Driver Manager.getConnection(〇〇〇); 
ResultSet rs = statement.executeQuery(sql); 
java.sql.ResultSetMetaData metaData = rs.getMetaData();
int columnCount = metaData.getColumnCount();

for (int i = 1; i <= columnCount; i++) {
    // 列が存在する場合はフラグを立てる
    columnExists.put(metaData.getColumnName(i), true);
}

while (rs.next()) {
    // ACの場合に{A, "", C}としたい場合(無いところは空白)
    String[] strArray = new String[columnNames.length];
    for (int i = 0; i < columnNames.length; i++) {
        // フラグが立っている列はデータを取得、フラグが立っていないなら空白
        strArray[i] = columnExists.get(columnNames[i]) ? rs.getString(columnNames[i]) : "";
    }
    /*
    // ACの場合に{A, C}としたい場合(無いところは詰める)
    ArrayList<String> tmp = new ArrayList<String>();
    for (int i = 0; i < columnNames.length; i++) {
        if(columnExists.get(columnNames[i])){
            // フラグが立っているならArrayListにaddする
            tmp.add(rs.getString(columnNames[i]));
        }
    }
    // ArrayListをString配列に変換
    String[] strArray = tmp.toArray(new String[tmp.size()]);
    */
    array.add(strArray);
}

列が変更されてもcolumnNamesをいじるだけで修正可能です。
ソラで書いてるので間違ってたらごめんなさい。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

以下でできるかも知れません

        ArrayList<String[]> array = new ArrayList<String[]>();
        ArrayList<String> a = new ArrayList<String>();

        try (Connection con = DriverManager.getConnection(url, user, pas);
                Statement stmt = con.createStatement();
                ResultSet rs = stmt.executeQuery(sql)) {
            java.sql.ResultSetMetaData Dat = rs.getMetaData();
            int col = Dat.getColumnCount();
            String A = "";
            String B = "";
            String C = "";

            for (int i = 1; i <= col; i++) {
                String name = Dat.getColumnName(i);
                if (name.equals("A")) {
                    A = name;
                    a.add(A);
                }
                if (name.equals("B")) {
                    B = name;
                    a.add(B);
                }
                if (name.equals("C")) {
                    C = name;
                    a.add(C);
                }

            }

            while (rs.next()) {
                A = "";
                B = "";
                C = "";
                for (String v : a) {
                    if (v.equals("a"))
                        A = rs.getString("a");
                    if (v.equals("b"))
                        B = rs.getString("b");
                    if (v.equals("c"))
                        C = rs.getString("c");
                }
                array.add(new String[] { A, B, C });
            }

        } catch (SQLException e) {
        }

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

同じタグがついた質問を見る

  • Java

    14391questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。