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-サンプルコードを学習することをお勧めします。