从java如何调用存储过程传递oracle游标作为参数

时间:2011-06-28 14:47:26

标签: java oracle ibatis jdbc-odbc

我正在使用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? 

2 个答案:

答案 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。

您必须重新设计应用程序,以便只从另一个存储过程调用带有输入光标的存储过程。