Мне нужна помощь, чтобы вызвать хранимую процедуру Oracle в Groovy и получить ResultSet с помощью выходного параметра.Я могу вызвать хранимую процедуру с выходными параметрами других типов данных, но для CURSOR я не могу найти путь.
«Я всегда получаю сообщение об ошибке» java.sql.SQLException: Курсор закрыт. «Параметр(ниже): " Sql.out (OracleTypes.CURSOR), // lista de possiveis varios items consumir "
Ниже моего кода (соединение уже открыто I
def consumeProvisioning(Sql sql) {
int nRes
sql.call("{call Provisioning.ConsumirAprovisionamento(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)}",
[
Sql.out(Sql.INTEGER.type), // quantidade possivel de consumir
new java.sql.Date(2012,1,1), // Data Para Validação
'testclient0000001', // IDCliente
'*', // IDCatalogo
'*', // Titulo
'*', // IDObjecto
'*', // IDAcervo
'*', // Autor
'*', // Origem
'*', // ZonaGeo
'FOTO', // Tipo Conteudo
'*', // Canal
'*', // Context
'*', // URLString
1, // Quantidade a consumir
'UNI', // Unidade do Stock
new java.sql.Date(2011,1,1), // Data Conteudo
1, // Mes
1, // Dia
1, // Hora
1, // Minuto
'GLOBAL_IMAGEM', // Site client
1, // ScopeID
'testclient0000001@user.com', //UserID
null, // Tag
null, // Metadado
'*', // FOTO FORMATO
'*', // FOTO QUALIDADE
null, // Video Formato
null, // Video Qualidade
null, // Som Formato
null, // Som Qualidade
null, // Artigo Formato
null, //IDProvisioningMaster
null, // Data de validade a colocar no consumo inline. Normalmente vai a null, pois o provisioning encarrega-se de verificar qual a mais adequada
new java.sql.Date(2011,12,31), // CriadoEm
'josecruz', // CriadoPor
new java.sql.Date(2011, 12, 31), // ActualizadoEm
'josecruz', // ActualizadoPor
Sql.out(OracleTypes.CURSOR), // lista de possiveis varios items a consumir
'FOTO2CONSUME1' // ID do objecto a consumir
]) {param1, param2 -> nRes = param1}
nRes
}
спасибо! Хосе Круз