在 Oracle 中调用 Java 存储过程
Posted
技术标签:
【中文标题】在 Oracle 中调用 Java 存储过程【英文标题】:Calling Java Stored Procedure in Oracle 【发布时间】:2014-01-29 17:30:56 【问题描述】:我正在尝试为 Oracle 创建一个 Java 存储过程,如下 Example 7-2 Fibonacci Sequence.
我经历了完全相同的过程,但是在执行代码时
SQL> VARIABLE n NUMBER
SQL> VARIABLE f NUMBER
SQL> EXECUTE :n := 7;
SQL> CALL fib(:n) INTO :f;
我收到以下回复:
anonymous block completed
Error starting at line 4 in command:
CALL fib(:n) INTO :f
Error report:
SQL Error: ORA-01008: not all variables bound
01008. 00000 - "not all variables bound"
*Cause:
*Action:
谁能帮忙?
【问题讨论】:
【参考方案1】:Oracle 文档中有很多编码错误(有时是遗漏,有时是错误)...无论如何,我认为问题在于该类是如何加载的。
尝试像这样加载类:
create or replace and compile java source named Fibonacci as
public class Fibonacci
public static int fib (int n)
if (n == 1 || n == 2)
return 1;
else
return fib(n - 1) + fib(n - 2);
确保函数包装器有效,然后重试。
CREATE OR REPLACE FUNCTION fib (n NUMBER) RETURN NUMBER
AS LANGUAGE JAVA
NAME 'Fibonacci.fib(int) return int';
我尝试后得到了正确的输出。
SQL> VARIABLE n NUMBER
SQL> VARIABLE f NUMBER
SQL> EXECUTE :n := 7;
PL/SQL procedure successfully completed
n
---------
7
SQL> CALL fib(:n) INTO :f;
Method called
n
---------
7
f
---------
13
SQL> PRINT f
f
---------
13
【讨论】:
在 SQL Developer 上完成此操作,但仍然出现相同的错误。我想我错过了一些可以理解的东西 调用 fib(:n) INTO :f;在 SQL Developer 中执行时行导致问题【参考方案2】:我对 SQL Developer 产品了解不够,以上内容可能仅适用于 SQL Plus。
试试:
SELECT fib(7) FROM dual;
【讨论】:
以上是关于在 Oracle 中调用 Java 存储过程的主要内容,如果未能解决你的问题,请参考以下文章
如何在java中调用包含用户定义类型的oracle存储过程?
在 Java 中调用 Oracle 存储过程时如何避免核心转储