2

我会procedure使用function.JDBC

就最佳实践和性能而言,最好使用 a functionwhich return aSYS_REFCURSOR或使用 a procedurewhich return a SYS_REFCURSOR

例如。

Procedure

create or replace procedure my_proc(p_deptno IN number,p_emp_no IN varchar2
    , p_cursor OUT SYS_REFCURSOR)
    is
    begin
    open p_cursor FOR
    select *
    from emp
    where deptno = p_deptno and emp_number=p_emp_no;
    end proc;
    /


Function

CREATE OR REPLACE FUNCTION my_func (p_deptno IN number,p_emp_no IN varchar2)
   RETURN SYS_REFCURSOR
AS
   p_cursor   SYS_REFCURSOR;
BEGIN
   OPEN p_cursor FOR
      select *
        from emp
        where deptno = p_deptno and emp_number=p_emp_no;
   RETURN p_cursor;
END;
/

以上哪一项是更好的选择?有人可以对此提供一些见解吗?任何帮助都是非常可观的。

谢谢

4

1 回答 1

3

从性能的角度来看,这并不重要。

通常,如果 PL/SQL 块的目的是向调用者返回某些内容,则它应该在函数中。如果 PL/SQL 块的目的是做某事(删除、插入、更新等),它应该在一个过程中。由于这段代码的目的是向调用者返回一些东西,所以它是一个函数是合适的。

于 2012-06-27T03:57:21.913 回答