Как я могу вернуть два столбца в функцию? - PullRequest
0 голосов
/ 30 ноября 2018

Как я могу вернуть два столбца в функцию?

Например: "EmployeeName | salary" и значения "Jonas Daniel | $2500$

1 Ответ

0 голосов
/ 30 ноября 2018

Использование курсора ссылки - один из вариантов:

SQL> create or replace function f_test (par_empno in number)
  2  return sys_refcursor
  3  is
  4    rc sys_refcursor;
  5  begin
  6    open rc for select ename, sal from emp
  7                where empno = par_empno;
  8    return rc;
  9  end;
 10  /

Function created.

SQL> select f_test(7839) from dual;

F_TEST(7839)
--------------------
CURSOR STATEMENT : 1

CURSOR STATEMENT : 1

ENAME             SAL
---------- ----------
KING            10000


SQL>

Или вы можете попробовать этот подход:

SQL> create or replace type t_test_row is object
  2    (ename     varchar2(20),
  3     sal       number);
  4  /

Type created.

SQL> create or replace type t_test_tab is table of t_test_row;
  2  /

Type created.

SQL> create or replace function f_test (par_empno in number)
  2    return t_test_tab
  3  is
  4    l_tab t_test_tab := t_test_tab();
  5  begin
  6    select t_test_row(ename, sal)
  7    bulk collect into l_tab
  8    from emp
  9    where empno = par_empno;
 10
 11    return l_tab;
 12  end;
 13  /

Function created.

SQL> select f_test(7839) from dual;

F_TEST(7839)(ENAME, SAL)
--------------------------------------------------------------------------------
T_TEST_TAB(T_TEST_ROW('KING', 10000))

SQL> -- Or, a nice presentation
SQL> select * from table(f_test(7839));

ENAME                       SAL
-------------------- ----------
KING                      10000

SQL>

Или вы можете создать процедуру:

SQL> set serveroutput on
SQL> create or replace procedure p_test (par_empno in number,
  2                                      par_ename out varchar2,
  3                                      par_sal   out number)
  4  is
  5  begin
  6    select ename, sal
  7      into par_ename, par_sal
  8      from emp
  9      where empno = par_empno;
 10  end;
 11  /

Procedure created.

SQL> declare
  2    l_ename varchar2(20);
  3    l_sal   number;
  4  begin
  5    p_test(7839, l_ename, l_sal);
  6    dbms_output.put_line('Name = ' || l_ename ||', salary = ' || l_sal);
  7  end;
  8  /
Name = KING, salary = 10000

PL/SQL procedure successfully completed.

SQL>

Но, если вы намеревались вернуть два скалярных значения, вам может не повезти.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...