我正在使用Java + iBatis并且需要调用以光标作为参数的Oracle存储过程。谷歌在找到如何调用存储过程的代码示例方面没有帮助我,该存储过程接受游标作为java中的参数。
如何实现这一目标?
步骤中的情景:
1. Java calls a Stored Proc passing primitives (varchar, char, etc) as
parameters
2. Java retrieves the cursor returned from Step 1
3. Java calls a Stored Proc passing cursor from Step 2 as an argument //how?
答案 0 :(得分:1)
如果这些是真正的唯一步骤 - 也就是说你在两次调用之间没有做任何重要的事情 - 那么对我来说更有意义的是避免返回Java。
如果第一个程序实际上是一个函数,你可以简单地执行一个嵌套调用:
BEGIN proc2(proc1(...)); END;
游标在Oracle中传递,根本不需要由Java处理。
如果您的第一个过程是将游标作为OUT参数返回的过程,您可以为它编写一个包装函数并执行相同的操作:
CREATE OR REPLACE FUNCTION func1(...)
RETURN SYS_REFCURSOR
AS
foo SYS_REFCURSOR;
BEGIN
proc1(..., foo);
RETURN foo;
END func1;
/
然后BEGIN proc2(func1(...)); END;
应该有用。
现在,如果您确实需要在两次调用之间使用Java,那么在从第一个过程中检索输出值时,我会尝试使用OracleTypes.CURSOR
,然后将该对象传递给第二个过程。我不知道这是否有效;如果没有,那么可能没有直接的方法去做。
答案 1 :(得分:0)
你不能这样做。
传递给Oracle存储过程的游标表示具有只有Oracle可以提供的API的对象。您的Java程序对游标的了解不足以创建某种对象,该对象将代理它并将调用转发回Oracle。
您必须重新设计应用程序,以便只从另一个存储过程调用带有输入光标的存储过程。