JDBC-ストアドプロシージャ

使い方を学びました Stored ProceduresJDBC-ステートメントの章について説明しながら、JDBCで。この章はそのセクションに似ていますが、JDBCSQLエスケープ構文に関する追加情報を提供します。

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();
}

studyCallable-サンプルコードで詳細を調査しました。

JDBCSQLエスケープ構文

エスケープ構文を使用すると、標準のJDBCメソッドとプロパティを使用して、使用できないデータベース固有の機能を柔軟に使用できます。

一般的なSQLエスケープ構文の形式は次のとおりです。

{keyword 'parameters'}

以下のエスケープシーケンスは、JDBCプログラミングの実行時に非常に役立ちます。

d、t、tsキーワード

これらは、日付、時刻、およびタイムスタンプのリテラルを識別するのに役立ちます。ご存知のように、2つのDBMSが同じ方法で時刻と日付を表すことはありません。このエスケープ構文は、ターゲットデータベースの形式で日付または時刻をレンダリングするようにドライバーに指示します。例-

{d 'yyyy-mm-dd'}

ここで、yyyy =年、mm =月; dd =日付。この構文の使用{d'2009-09-03 '}は2009年3月9日です。

これは、テーブルに日付を挿入する方法を示す簡単な例です-

//Create a Statement object
stmt = conn.createStatement();
//Insert data ==> ID, First Name, Last Name, DOB
String sql="INSERT INTO STUDENTS VALUES" +
             "(100,'Zara','Ali', {d '2001-12-16'})";

stmt.executeUpdate(sql);

同様に、次の2つの構文のいずれかを使用できます。 t または ts

{t 'hh:mm:ss'}

ここで、hh =時間。mm =分; ss =秒。この構文を使用すると、{t'13:30:29 '}は午後1時30分29秒になります。

{ts 'yyyy-mm-dd hh:mm:ss'}

これは、タイムスタンプを表す「d」と「t」の上記の2つの構文を組み合わせた構文です。

エスケープキーワード

このキーワードは、LIKE句で使用されるエスケープ文字を識別します。0個以上の文字に一致するSQLワイルドカード%を使用する場合に便利です。例-

String sql = "SELECT symbol FROM MathSymbols
              WHERE symbol LIKE '\%' {escape '\'}";
stmt.execute(sql);

バックスラッシュ文字(\)をエスケープ文字として使用する場合、バックスラッシュもJavaエスケープ文字であるため、Java文字列で2つのバックスラッシュ文字を使用する必要があります。

fnキーワード

このキーワードは、DBMSで使用されるスカラー関数を表します。たとえば、SQL関数の長さを使用して文字列の長を取得できます-

{fn length('Hello World')}

これは、文字列「HelloWorld」の長さである11を返します。

キーワードを呼び出す

このキーワードは、ストアード・プロシージャーを呼び出すために使用されます。たとえば、INパラメータを必要とするストアドプロシージャの場合、次の構文を使用します-

{call my_procedure(?)};

INパラメータを必要とし、OUTパラメータを返すストアドプロシージャの場合、次の構文を使用します-

{? = call my_procedure(?)};

ojキーワード

このキーワードは、外部結合を示すために使用されます。構文は次のとおりです-

{oj outer-join}

ここで、outer-join = table {LEFT | RIGHT | FULL} OUTERJOIN {table | 検索条件でのouter-join}。例-

String sql = "SELECT Employees 
              FROM {oj ThisTable RIGHT
              OUTER JOIN ThatTable on id = '100'}";
stmt.execute(sql);