Následující kód vám může pomoci získat proměnnou SYS_REFCURSOR
z anonymního bloku Oracle.
Měli bychom se zaměřit na několik klíčových detailů:
- Třída
groovy.sql.Sql
nemá odpovídajícíOutParameter
a uděláme to ručně jakoCURSOR_PARAMETER
a předejte jejsql.call
metoda - Zvažte, že blok začíná
{call DECLARE
a končíEND }
bez středníku za END. Jinak můžeme získat špatně rozpoznatelnouSQLException
v obličeji. - Otazníky
?
uvnitřsqlString
jsou místa pro vazby parametrů. Vazby jsou vytvořeny v přirozeném pořadí a přebírají hodnoty zparametersList
.- V tomto příkladu máme jedinou vazbu, tedy
?
váže se s CURSOR_PARAMETER s hodnotouOUT
parametr předávaného typu;
- V tomto příkladu máme jedinou vazbu, tedy
- Po
sql.call
existuje pouze jeden vstup do uzavření aResultSet rs
zadejte řádky kurzorumy_cur
deklarováno v anonymním bloku. - Můžeme zjednodušit
sqlString
pomocí funkce vracejícíSYS_REFCURSOR
místo procedury sOUT
parametr. Mohlo by to tedy vypadat takto"{call BEGIN ? := MY_FUNC(); END}"
nebo dokonce"{? = 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")
}
};
P.S. A děkuji za otázku.