2

如何使用 EclipseLink 调用返回 sys_refcursor 的 Oracle 函数?

有一个文档说明了调用函数,但不确定如何调用返回 sys_refcursor 的函数。

http://eclipse.org/eclipselink/documentation/2.4/jpa/extensions/a_namedstoredfunctionquery.htm

我试过如下

@NamedStoredFunctionQuery(name = "findEmployees", 
                          functionName = "getEmps", 
                          parameters = 
                          { @StoredProcedureParameter(queryParameter = "user", 
                                                      name = "username", 
                                                      direction = Direction.IN, 
                                                      type = String.class)
            } , 
    returnParameter = @StoredProcedureParameter(queryParameter = "c_cursor")
)

甲骨文功能

CREATE or REPLACE FUNCTION getEmps (username varchar2)
      RETURN SYS_REFCURSOR
   AS
   c_cursor   SYS_REFCURSOR;
   BEGIN
   OPEN c_cursor FOR 
   SELECT * FROM employees where emp_no=username;
   RETURN c_cursor;

但是,当我执行时,出现以下错误

内部异常:java.sql.SQLException:ORA-06550:第 1 行,第 13 列:PLS-00382:表达式类型错误 ORA-06550:第 1 行,第 7 列:PL/SQL:语句被忽略

错误代码:6550 调用:开始?:= getEmps(用户名=>?); 结尾; bind => [=> c_cursor, S7845] 查询:在 org.eclipse.persistence.internal.jpa.QueryImpl.getDetailedException(QueryImpl.java:378) 在 org.eclipse.persistence.internal 的 DataReadQuery(name="findEmps" )。 jpa.QueryImpl.executeReadQuery(QueryImpl.java:260) 在 org.eclipse.persistence.internal.jpa.QueryImpl.getResultList(QueryImpl.java:469)

我该如何解决这个问题?

4

2 回答 2

1

我认为您必须指定Direction函数参数

CREATE or REPLACE FUNCTION getEmps (username IN varchar2)
      RETURN SYS_REFCURSOR
   AS
   c_cursor   SYS_REFCURSOR;
   BEGIN
   OPEN c_cursor FOR 
   SELECT * FROM employees where emp_no=username;
   RETURN c_cursor;

请试一试!

于 2015-01-15T13:58:03.960 回答
0

将函数保存在数据库中,然后使用 FUNCTION 调用执行它。

例如,我有一个名为“SUMACAMPO”的 Oracle 函数,它将数据库的两列相加:

在此处输入图像描述

我的查询:

select Function('SUMACAMPO') from Table t

Java代码:

Query q = em.createQuery("select Function('SUMACAMPO') from Table t");
List<Object[]> resultado= q.getResultList();
LOG.info("Resultado consulta: {}",resultado);

因此,在 LOG 中执行查询的输出为:

Resultado consulta: [4413700]
于 2019-02-22T16:45:20.503 回答