Я использую Groovy
script в Mule ESB
для получения выходных параметров из Oracle
хранимой процедуры (включая курсор) и получения исключения.
Минимальный пример:
import groovy.sql.Sql
import oracle.jdbc.pool.OracleDataSource
import oracle.jdbc.driver.OracleTypes
def ds = new OracleDataSource()
// setting data source parameters here
def sql = new Sql(ds)
def data = []
sql.call("""declare
result_table sys_refcursor;
begin
open result_table for select 1 as a from dual;
insert into CURSOR_TEST (ID) values (1);
commit;
${Sql.resultSet OracleTypes.CURSOR} := result_table;
insert into CURSOR_TEST (ID) values (2);
commit;
end;
"""
){ table ->
throw new RuntimeException("Never getting this exception.")
table.eachRow {
data << it.toRowResult()
}
}
sql.close()
return data
Ошибка:
Message : java.sql.SQLException: Closed Statement (javax.script.ScriptException) Code : MULE_ERROR--2 -------------------------------------------------------------------------------- Exception stack is: 1. Closed Statement(SQL Code: 17009, SQL State: + 99999) (java.sql.SQLException) oracle.jdbc.driver.SQLStateMapping:70 (null) 2. java.sql.SQLException: Closed Statement (javax.script.ScriptException) org.codehaus.groovy.jsr223.GroovyScriptEngineImpl:323 (http://java.sun.com/j2ee/sdk_1.3/techdocs/api/javax/script/ScriptException.html) 3. java.sql.SQLException: Closed Statement (javax.script.ScriptException)
(org.mule.api.transformer.TransformerException) org.mule.scripting.transformer.ScriptTransformer: 39 (http://www.mulesoft.org/docs/site/current3/apidocs/org/mule/api/transformer/TransformerException.html) -------------------------------------------------- ------------------------------ Трассировка стека прерываний корня: java.sql.SQLException: Закрытое выражение at oracle.jdbc.driver.SQLStateMapping.newSQLException(SQLStateMapping.java:70) at oracle.jdbc.driver.DatabaseError.newSQLException(DatabaseError.java:133) at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:199) + Еще 3 (установить регистрацию уровня отладки или '-Dmule.verbose.exceptions = true' для всего) ************************************************** ******************************
Select
from CURSOR_TEST
возвращает 1
и 2
.
Версия сервера Oracle: Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit Production
.
Версия мула: 3.5.0
.
Я использую jdbc\lib\ojdbc6.jar
из версии клиента oracle 11.1.0.7.0
.
Что я делаю неправильно?