Følgende kode kan hjælpe dig med at få variablen SYS_REFCURSOR
fra Oracle anonym blok.
Vi bør fokusere på nogle få nøgledetaljer:
- Klasse
groovy.sql.Sql
har ikke tilsvarendeOutParameter
og vi laver det manuelt somCURSOR_PARAMETER
og send det tilsql.call
metode - Tænk på, at blokken starter med
{call DECLARE
og slutter medEND }
uden semikolon efter SLUT. Ellers kan vi få en dårligt genkendeligSQLException
i ansigtet. - Spørgsmålstegnet
?
inde isqlString
er steder for parameterbindinger. Bindinger er lavet i den naturlige rækkefølge med værdier fraparametersList
.- I dette eksempel har vi den eneste binding, så
?
binder med CURSOR_PARAMETER og behandler værdien somOUT
parameter af bestået type;
- I dette eksempel har vi den eneste binding, så
- Der er kun én indtastning af lukning efter
sql.call
ogResultSet rs
angiv rækker med markørmy_cur
erklæret i anonym blok. - Vi kan forenkle
sqlString
ved at bruge en funktion, der returnererSYS_REFCURSOR
i stedet for en procedure medOUT
parameter. Så det kunne se sådan ud"{call BEGIN ? := MY_FUNC(); END}"
eller endda"{? = 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. Og tak for spørgsmålet.