1

给定以下使用 loadjava 加载到数据库中的 Java:

package grassie.example;

public class Example {

    public static String test(){
        return "Hello World!";
    }
}

并给出以下 Oracle 存储函数:

CREATE OR REPLACE FUNCTION TEST_FUNCTION RETURN VARCHAR2
AS LANGUAGE JAVA
NAME 'grassie.example.Example.test() RETURN java.lang.String';

为什么函数无法编译并出现以下错误?:

Error(3,1): PLS-00311: the declaration of "grassie.example.Example.test() RETURN java.lang.String" is incomplete or malformed

Oracle 客户端是 9.2.0.8.0,数据库是 9.2.0.8.0。使用 SQL Developer 2.1.0.63

编辑:根据下面的答案修改了我的问题。

为了进一步澄清,我创建了这个简单的测试类和函数,因为我遇到了更复杂的 Java 和存储函数的问题,它们接受和返回各种参数类型。

4

3 回答 3

2

去掉函数声明中的空括号:

CREATE OR REPLACE FUNCTION TEST_FUNCTION RETURN VARCHAR2
AS LANGUAGE JAVA
NAME 'grassie.example.Example.test() RETURN java.lang.String';

更新:

Java关键字应该是小写的。尝试在子句中替换RETURNwith 。returnNAME

于 2010-02-26T12:58:27.283 回答
1

如果函数没有参数,则不需要括号 ():

SQL> CREATE OR REPLACE FUNCTION TEST_FUNCTION() RETURN NUMBER AS
  2  BEGIN
  3     RETURN 0;
  4  END;
  5  /

Warning: Function created with compilation errors

SQL> CREATE OR REPLACE FUNCTION TEST_FUNCTION RETURN NUMBER AS
  2  BEGIN
  3     RETURN 0;
  4  END;
  5  /

Function created
于 2010-02-26T12:56:37.240 回答
0

函数定义应该像下面的代码,

CREATE OR REPLACE FUNCTION NEMO_SCM.TEST_FUNCTION RETURN VARCHAR2
AS LANGUAGE JAVA
NAME 'grassie.example.Example.test() **return** java.lang.String';
于 2019-11-18T09:17:41.470 回答