在 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存储过程?

Oracle如何创建存储过程和如何调用存储过程

在 Java 中调用 Oracle 存储过程时如何避免核心转储

最近几天一直在搞Mybatis调用存储过程的问题,用<select>标签写的那种!然后用Java里写调用函数

使用带有布尔输入参数的 PL/SQL 在 oracle 中调用 java 存储过程