
現在、あるWEBシステムの開発に携わっているものですが、
DBの検索が非常に遅いという問題にぶつかっている状態です。
そこで、問題点をできるだけ明確にするために
下記の3パターンで計測を試みてみました。
(1) Statement クラスの executeQueryメソッドを使用してのデータ取得
(2) PreparedStatement クラスの executeQueryメソッドを使用してのデータ取得
※但し、バインド変数を使用しない。
(3) PreparedStatement クラスの executeQueryメソッドを使用してのデータ取得
※但し、バインド変数を使用する。
計測は、次の条件で行いました。
3つ全てが同一のSQL。
(バインド変数を使用する場合も、最終的には同じ静的SQLになるようにする。)
時間はexecuteQueryメソッドの前後で計測する。
(executeQueryメソッドコールの直前と直後の時間の差とします。)
結果は(1)、(2)では、約3秒程度とほぼ同タイム。しかし、(3)はでは1時間経ってもレスポンスが返ってこない状況でした。
これはどういう理由が考えられるのでしょうか。今、ここから先に進めなくて大変困っています。
同じような現象に遭遇した経験をお持ちの方、もしくは、この先どのように解析を進めるべきなのか示唆できる方。アドバイスをどうかよろしくお願い致します。
なお、計測は下記の環境にて行っております。
OS:Windows XP Pro
WAS:WebSphere 5.0.2
DB:DB2 Version 7
java:java(TM) 2 Runtime Environment, Standard Edition (build 1.3.1)
JDBCドライバ:Version 2.0 (使用クラス:COM.ibm.db2.jdbc.app.DB2Driver)
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Java初級 引数に適用できません
-
レコード件数の表示
-
Javaの関数名が長い?
-
abstract と static を一緒に付...
-
return new使用時
-
C# 点の描き方をおしえてくだ...
-
リストボックスの並べ替え (VB...
-
スーパークラスからサブクラス...
-
getBunds()の使い方
-
クラスを作るとメソッドの数が...
-
メソッドとコンストラクタ
-
java ジェネリックスに関して
-
メソッドの引数に指定されてい...
-
C# でメソッドに送られてきたOb...
-
Google Apps Script で getRang...
-
なぜprotected overrideなのか
-
VB.Net: クラスの共有メソッド...
-
C言語での文字列より値を抜き出す
-
コマンドライン引数のチェック
-
javaのprivateって?
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
レコード件数の表示
-
Java初級 引数に適用できません
-
String.containsの反対機能はあ...
-
別クラスのmainメソッドの実行
-
abstract と static を一緒に付...
-
StringBufferからStringへキャ...
-
説明文書でのメソッド・変数の...
-
Java初心者です、エラーの意味...
-
YYYYMMDD書式の日付に対する適...
-
コマンドライン引数のチェック
-
Google Apps Script で getRang...
-
staticのメリット、デメリット
-
メソッドの引数に指定されてい...
-
スーパークラスからサブクラス...
-
return new使用時
-
メソッド宣言の戻り値の型にク...
-
インターフェースについて
-
CSVから読み込んだデータの保持...
-
問題の意味が分かりません
-
JavaからCへ
おすすめ情報