JDBC-ステートメント、PreparedStatementおよびCallableStatement
接続が取得されると、データベースと対話できます。JDBCステートメント、CallableStatement、およびPreparedStatementインターフェースは、SQLまたはPL / SQLコマンドを送信し、データベースからデータを受信できるようにするメソッドとプロパティを定義します。
また、データベースで使用されるJavaデータ型とSQLデータ型の間のデータ型の違いを埋めるのに役立つメソッドも定義します。
次の表に、使用するインターフェイスを決定するための各インターフェイスの目的の概要を示します。
インターフェイス | 推奨用途 |
---|---|
ステートメント | これをデータベースへの汎用アクセスに使用します。実行時に静的SQLステートメントを使用している場合に便利です。ステートメントインターフェイスはパラメータを受け入れることができません。 |
PreparedStatement | SQLステートメントを何度も使用する予定がある場合は、これを使用します。PreparedStatementインターフェースは、実行時に入力パラメーターを受け入れます。 |
CallableStatement | データベースのストアドプロシージャにアクセスする場合に使用します。CallableStatementインターフェースは、ランタイム入力パラメーターを受け入れることもできます。 |
ステートメントオブジェクト
ステートメントオブジェクトの作成
次の例のように、Statementオブジェクトを使用してSQLステートメントを実行する前に、ConnectionオブジェクトのcreateStatement()メソッドを使用してSQLステートメントを作成する必要があります。
Statement stmt = null;
try {
stmt = conn.createStatement( );
. . .
}
catch (SQLException e) {
. . .
}
finally {
. . .
}
Statementオブジェクトを作成したら、それを使用して、3つのexecuteメソッドのいずれかでSQLステートメントを実行できます。
boolean execute (String SQL):ResultSetオブジェクトを取得できる場合は、ブール値trueを返します。それ以外の場合は、falseを返します。このメソッドは、SQL DDLステートメントを実行する場合、または真に動的なSQLを使用する必要がある場合に使用します。
int executeUpdate (String SQL):SQLステートメントの実行によって影響を受ける行数を返します。このメソッドを使用して、影響を受ける行数が予想されるSQLステートメント(INSERT、UPDATE、またはDELETEステートメントなど)を実行します。
ResultSet executeQuery (String SQL):ResultSetオブジェクトを返します。SELECTステートメントの場合のように、結果セットを取得する予定の場合は、このメソッドを使用します。
ステートメントオブジェクトを閉じる
データベースリソースを節約するためにConnectionオブジェクトを閉じるのと同じ理由で、Statementオブジェクトも閉じる必要があります。
close()メソッドを呼び出すだけでうまくいきます。最初にConnectionオブジェクトを閉じると、Statementオブジェクトも閉じます。ただし、適切なクリーンアップを確実にするために、Statementオブジェクトを常に明示的に閉じる必要があります。
Statement stmt = null;
try {
stmt = conn.createStatement( );
. . .
}
catch (SQLException e) {
. . .
}
finally {
stmt.close();
}
理解を深めるために、ステートメント-サンプルチュートリアルを学習することをお勧めします。
PreparedStatementオブジェクト
PreparedStatementインタフェースを使用すると、一般的なStatementオブジェクト上の利点のカップルと機能を追加できますStatementインタフェースを拡張します。
このステートメントは、引数を動的に提供する柔軟性を提供します。
PreparedStatementオブジェクトの作成
PreparedStatement pstmt = null;
try {
String SQL = "Update Employees SET age = ? WHERE id = ?";
pstmt = conn.prepareStatement(SQL);
. . .
}
catch (SQLException e) {
. . .
}
finally {
. . .
}
JDBCのすべてのパラメーターは、 ?パラメータマーカーとして知られている記号。SQLステートメントを実行する前に、すべてのパラメーターに値を指定する必要があります。
ザ・ setXXX() メソッドは値をパラメーターにバインドします。ここで XXX入力パラメータにバインドする値のJavaデータ型を表します。値の指定を忘れると、SQLExceptionが発生します。
各パラメーターマーカーは、その序数位置によって参照されます。最初のマーカーは位置1、次の位置2などを表します。このメソッドは、0から始まるJava配列インデックスのメソッドとは異なります。
すべての Statement object'sデータベースと対話するためのメソッド(a)execute()、(b)executeQuery()、および(c)executeUpdate()もPreparedStatementオブジェクトで機能します。ただし、メソッドは、パラメーターを入力できるSQLステートメントを使用するように変更されています。
PreparedStatementオブジェクトを閉じる
Statementオブジェクトを閉じるのと同じ理由で、PreparedStatementオブジェクトも閉じる必要があります。
close()メソッドを呼び出すだけでうまくいきます。最初にConnectionオブジェクトを閉じると、PreparedStatementオブジェクトも閉じられます。ただし、適切なクリーンアップを確実にするために、PreparedStatementオブジェクトを常に明示的に閉じる必要があります。
PreparedStatement pstmt = null;
try {
String SQL = "Update Employees SET age = ? WHERE id = ?";
pstmt = conn.prepareStatement(SQL);
. . .
}
catch (SQLException e) {
. . .
}
finally {
pstmt.close();
}
理解を深めるために、Prepare-サンプルコードを調べてみましょう。
CallableStatementオブジェクト
ConnectionオブジェクトがStatementオブジェクトとPreparedStatementオブジェクトを作成するのと同じように、CallableStatementオブジェクトも作成します。これは、データベースのストアドプロシージャへの呼び出しを実行するために使用されます。
CallableStatementオブジェクトの作成
次のOracleストアドプロシージャを実行する必要があるとします。
CREATE OR REPLACE PROCEDURE getEmpName
(EMP_ID IN NUMBER, EMP_FIRST OUT VARCHAR) AS
BEGIN
SELECT first INTO EMP_FIRST
FROM Employees
WHERE ID = EMP_ID;
END;
NOTE: 上記のストアドプロシージャはOracle用に記述されていますが、MySQLデータベースを使用しているため、次のようにMySQL用の同じストアドプロシージャを記述して、EMPデータベースに作成します。
DELIMITER $$
DROP PROCEDURE IF EXISTS `EMP`.`getEmpName` $$
CREATE PROCEDURE `EMP`.`getEmpName`
(IN EMP_ID INT, OUT EMP_FIRST VARCHAR(255))
BEGIN
SELECT first INTO EMP_FIRST
FROM Employees
WHERE ID = EMP_ID;
END $$
DELIMITER ;
パラメータには、IN、OUT、およびINOUTの3つのタイプがあります。PreparedStatementオブジェクトは、INパラメーターのみを使用します。CallableStatementオブジェクトは、3つすべてを使用できます。
それぞれの定義は次のとおりです-
パラメータ | 説明 |
---|---|
に | SQLステートメントの作成時に値が不明なパラメーター。setXXX()メソッドを使用して、値をINパラメーターにバインドします。 |
アウト | 値が返されるSQLステートメントによって提供されるパラメーター。getXXX()メソッドを使用してOUTパラメーターから値を取得します。 |
INOUT | 入力値と出力値の両方を提供するパラメーター。変数をsetXXX()メソッドでバインドし、getXXX()メソッドで値を取得します。 |
次のコードスニペットは、 Connection.prepareCall() インスタンス化する方法 CallableStatement 前述のストアドプロシージャに基づくオブジェクト-
CallableStatement cstmt = null;
try {
String SQL = "{call getEmpName (?, ?)}";
cstmt = conn.prepareCall (SQL);
. . .
}
catch (SQLException e) {
. . .
}
finally {
. . .
}
文字列変数SQLは、パラメータプレースホルダーを使用してストアドプロシージャを表します。
CallableStatementオブジェクトの使用は、PreparedStatementオブジェクトの使用とよく似ています。ステートメントを実行する前に、すべてのパラメーターに値をバインドする必要があります。そうしないと、SQLExceptionが発生します。
INパラメータがある場合は、PreparedStatementオブジェクトに適用されるのと同じルールと手法に従ってください。バインドするJavaデータ型に対応するsetXXX()メソッドを使用します。
OUTおよびINOUTパラメーターを使用する場合は、追加のCallableStatementメソッドであるregisterOutParameter()を使用する必要があります。registerOutParameter()メソッドは、JDBCデータ型を、ストアドプロシージャが返すことが期待されるデータ型にバインドします。
ストアドプロシージャを呼び出したら、適切なgetXXX()メソッドを使用してOUTパラメータから値を取得します。このメソッドは、取得したSQL型の値をJavaデータ型にキャストします。
CallableStatementオブジェクトを閉じる
他のStatementオブジェクトを閉じるのと同じように、同じ理由でCallableStatementオブジェクトも閉じる必要があります。
close()メソッドを呼び出すだけでうまくいきます。最初にConnectionオブジェクトを閉じると、CallableStatementオブジェクトも閉じられます。ただし、適切なクリーンアップを確実にするために、常にCallableStatementオブジェクトを明示的に閉じる必要があります。
CallableStatement cstmt = null;
try {
String SQL = "{call getEmpName (?, ?)}";
cstmt = conn.prepareCall (SQL);
. . .
}
catch (SQLException e) {
. . .
}
finally {
cstmt.close();
}
理解を深めるために、Callable-サンプルコードを学習することをお勧めします。