次のコードは、SYS_REFCURSOR
の変数を取得するのに役立ちます Oracle匿名ブロックから。
いくつかの重要な詳細に焦点を当てる必要があります:
- クラス
groovy.sql.Sql
対応するOutParameter
がありませんCURSOR_PARAMETER
として手動で作成します それをsql.call
に渡します 方法 - ブロックが
{call DECLARE
で始まることを考慮してくださいEND }
で終わります ENDの後にセミコロンなし。そうしないと、認識しにくいSQLException
が発生する可能性があります。 顔に。 - 疑問符
?
sqlString
内 パラメータバインディングの場所です。バインディングは、parametersList
から値を取得する自然な順序で行われます。 。- この例では、バインディングが1つしかないため、
?
値をOUT
として扱うCURSOR_PARAMETERとバインドします 渡されたタイプのパラメータ;
- この例では、バインディングが1つしかないため、
-
sql.call
の後にクロージャに入るのは1つだけです およびResultSet rs
カーソルの行を提供するmy_cur
匿名ブロックで宣言されています。 -
sqlString
を簡略化できますSYS_REFCURSOR
を返す関数を使用するOUT
を使用したプロシージャの代わりに パラメータ。したがって、次のようになります。"{call BEGIN ? := MY_FUNC(); END}"
または"{? = call MY_FUNC()}"
を呼び出す
import groovy.sql.OutParameter
import groovy.sql.Sql
import oracle.jdbc.OracleTypes
import java.sql.ResultSet
def driver = 'oracle.jdbc.driver.OracleDriver'
def sql = Sql.newInstance('jdbc:oracle:thin:@my-server:1521:XXX', 'usr', 'psw', driver)
// special OutParameter for cursor type
OutParameter CURSOR_PARAMETER = new OutParameter() {
public int getType() {
return OracleTypes.CURSOR;
}
};
// look at some ceremonial wrappers around anonymous block
String sqlString = """{call
DECLARE
my_cur SYS_REFCURSOR;
BEGIN
STORED_PROCEDURE_NAME(my_cur);
? := my_cur;
END
}
""";
// the order of elements matches the order of bindings
def parametersList = [CURSOR_PARAMETER];
// rs contains the result set of cursor my_cur
sql.call(sqlString, parametersList) { ResultSet rs ->
while (rs.next()) {
println rs.getString("my_column")
}
};
追伸そして、質問をありがとう。