De volgende code kan u helpen om een variabele van SYS_REFCURSOR
. te krijgen van Oracle anoniem blok.
We moeten ons concentreren op een paar belangrijke details:
- Klasse
groovy.sql.Sql
heeft geen corresponderendeOutParameter
en we maken het handmatig alsCURSOR_PARAMETER
en geef het door aansql.call
methode - Bedenk dat het blok begint met
{call DECLARE
en eindigt metEND }
zonder puntkomma na END. Anders krijgen we een slecht herkenbareSQLException
in het gezicht. - De vraagtekens
?
binnen desqlString
zijn plaatsen voor parameterbindingen. Bindingen worden gemaakt in de natuurlijke volgorde en nemen waarden uitparametersList
.- In dit voorbeeld hebben we de enige binding, dus de
?
bindt met CURSOR_PARAMETER en behandelt de waarde alsOUT
parameter van doorgegeven type;
- In dit voorbeeld hebben we de enige binding, dus de
- Er is slechts één enter in afsluiting na
sql.call
enResultSet rs
geef rijen met cursormy_cur
gedeclareerd in anoniem blok. - We kunnen
sqlString
vereenvoudigen door een functie te gebruiken dieSYS_REFCURSOR
. retourneert in plaats van een procedure metOUT
parameter. Het zou er dus zo uit kunnen zien"{call BEGIN ? := MY_FUNC(); END}"
of zelfs"{? = 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 En bedankt voor de vraag.