El siguiente código puede ayudarlo a obtener la variable de SYS_REFCURSOR del bloque anónimo de Oracle.
Debemos centrarnos en algunos detalles clave:
- Clase
groovy.sql.Sqlno tieneOutParametercorrespondiente y lo hacemos manualmente comoCURSOR_PARAMETERy páselo asql.callmétodo - Considere que el bloque comienza con
{call DECLAREy termina conEND }sin punto y coma después de FIN. De lo contrario, podemos obtener unaSQLExceptionpoco reconocible en la cara. - Los signos de interrogación
?dentro desqlStringson lugares para enlaces de parámetros. Los enlaces se realizan en el orden natural tomando valores deparametersList.- En este ejemplo, tenemos el único enlace, por lo que
?se une con CURSOR_PARAMETER tratando el valor comoOUTparámetro de tipo pasado;
- En este ejemplo, tenemos el único enlace, por lo que
- Solo hay una entrada en el cierre después de
sql.callyResultSet rsproporcionar filas de cursormy_curdeclarado en bloque anónimo. - Podemos simplificar
sqlStringusando una función que devuelveSYS_REFCURSORen lugar de un procedimiento conOUTparámetro. Entonces podría verse así"{call BEGIN ? := MY_FUNC(); END}"o incluso"{? = 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")
}
};
PD Y gracias por la pregunta.