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

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

新規登録して質問してみよう
ただいま回答率
85.50%
Java

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

解決済

1回答

3892閲覧

executeBatchで複数のSQLを送信した場合の結果の取得方法がよくわからない

Shiori_Nakamura

総合スコア7

Java

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

0クリップ

投稿2018/03/17 16:59

編集2018/03/17 17:03

前提・実現したいこと

JDBCのexecuteBatchによる複数SQL送信について。
データベース内にテーブルは3つあります。
そのテーブルに登録されている件数を表示させるコードを書いています。

発生している問題・エラーメッセージ

http://www.techscore.com/tech/Java/JavaEE/JDBC/2-3/
↑を参考にaddBatchを使って3つのテーブルのcount文を一斉に送信したのですが、なかなかうまく取得できず、COUNT数を取る方法がいまいちよく分かりません。

該当のソースコード

Java

1try { 2Connection con = DriverManager.getConnection("jdbc:h2:~/hoge"); 3Statement pstmt = con.createStatement(); 4pstmt.addBatch("SELECT COUNT(SERIALNO) FROM TABLE1;"); 5pstmt.addBatch("SELECT COUNT(SERIALNO) FROM TABLE2;"); 6pstmt.addBatch("SELECT COUNT(SERIALNO) FROM TABLE3;"); 7int result[] = pstmt.executeBatch(); 8pstmt = con.createStatement(); 9 10while(rs.next()) { 11int hoge1Count = rs.getInt("COUNT"); 12int hoge2Count = rs.getInt("COUNT"); 13int hoge3Count = rs.getInt("COUNT"); 14hoge1.setText("HOGE1は" + hoge1Count + "件"); 15hoge2.setText("HOGE2は" + hoge2Count + "件"); 16hoge3.setText("HOGE3は" + hoge3Count + "件登録されています。"); 17} 18} catch (SQLException e) { 19e.printStackTrace(); 20}

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yukapome789

2018/03/18 01:15

>>なかなかうまく取得できず、 の意味がわからないのですが、例外が発生しているのですか?であれば例外メッセージを載せましょう。または、例外は発生していないが意図通りのカウント数が表示されないのですか?であればどういう理由で○が表示されるはずなのに×が表示される旨を載せましょう。
umyu

2018/03/18 04:27 編集

複数のテーブルの件数をCOUNTするでしたら、executeBatchを使わずにUNION ALL演算子を使えば良いように見受けられますが。要件としてexecuteBatchが必要なのでしょうか?あと、DBによってはシステムテーブルにユーザーテーブルの件数が登録されていることもあります。
guest

回答1

0

自己解決

他サイトに似たような質問があったため、自己解決しました。ありがとうございました。
https://oshiete.goo.ne.jp/qa/4386581.html

投稿2018/03/18 09:29

Shiori_Nakamura

総合スコア7

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問