Le code suivant peut vous aider à obtenir la variable de SYS_REFCURSOR
du bloc anonyme Oracle.
Nous devons nous concentrer sur quelques détails clés :
- Classe
groovy.sql.Sql
n'a pas deOutParameter
correspondant et nous le faisons manuellement en tant queCURSOR_PARAMETER
et passez-le àsql.call
méthode - Considérez que le bloc commence par
{call DECLARE
et se termine parEND }
sans point-virgule après END. Sinon, nous pouvons obtenir uneSQLException
mal reconnaissable au visage. - Les points d'interrogation
?
à l'intérieur desqlString
sont des emplacements pour les liaisons de paramètres. Les liaisons sont faites dans l'ordre naturel en prenant les valeurs deparametersList
.- Dans cet exemple, nous avons la seule liaison, donc le
?
se lie avec CURSOR_PARAMETER en traitant la valeur commeOUT
paramètre de type passé ;
- Dans cet exemple, nous avons la seule liaison, donc le
- Il n'y a qu'une seule entrée en fermeture après
sql.call
etResultSet rs
fournir des lignes de curseurmy_cur
déclaré en bloc anonyme. - Nous pouvons simplifier
sqlString
en utilisant une fonction renvoyantSYS_REFCURSOR
au lieu d'une procédure avecOUT
paramètre. Cela pourrait donc ressembler à ceci"{call BEGIN ? := MY_FUNC(); END}"
ou même"{? = 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")
}
};
PS Et merci pour la question.