Как изменить вызов функции PL/SQL, когда функция больше не конвейерная?
У меня есть PL/SQL функция выглядит так:
FUNCTION get_agent_statistics ( id NUMBER
RETURN agent_stats_t
PIPELINED;
И я выбираю из него (код iBatis):
SELECT * FROM table(pkg.get_agent_statistics(#id#))
Как я должен изменить этот выбор, если я удалю PIPELINED
выписка из функции?
2 ответа
Если вы получите рабочую скомпилированную процедуру без PIPELINED
заявление, вам не нужно менять свой SELECT
, Смотрите это - http://www.oracle-base.com/articles/misc/pipelined-table-functions.php
Когда вы удаляете PIPELINED
предложение из объявления функции, функция перестает быть табличной функцией PIPELINED, и в результате вам придется изменить тело функции, чтобы преобразовать ее в функцию TABLE, если вы все еще хотите использовать ее from
предложение или простая функция, которую вы не сможете использовать в from
пункт запроса.
добавление
Could I select something from non-pipelined function?
Да, если у вас есть функция TABLE, иначе нет. Вот пара примеров:
-- prerequisites
SQL> create or replace type T_rows as object(
2 e_name varchar2(21),
3 e_lname varchar2(21)
4 )
5 /
Type created
SQL> create or replace type T_tab is table of t_rows
2 /
Type created
-- PIPELINED TABLE function
SQL> create or replace function GetEnames
2 return T_Tab
3 pipelined
4 is
5 l_etab t_tab := t_tab();
6 begin
7 for i in (select first_name
8 , last_name
9 from employees)
10 loop
11 pipe row(t_rows(i.first_name, i.last_name));
12 --l_etab.extend;
13 --l_etab(l_etab.last) := t_rows(i.first_name, i.last_name);
14 end loop;
15 return ;--l_etab;
16 end;
17 /
Function created
SQL> select *
2 from table(getenames)
3 where rownum <= 5;
E_NAME E_LNAME
--------------------- ---------------------
Steven King
Neena Kochhar
Lex De Haan
Alexander Hunold
Bruce Ernst
-- non-pipelined table function
SQL> create or replace function GetEnames
2 return T_Tab
3
4 is
5 l_etab t_tab := t_tab();
6 begin
7 for i in (select first_name
8 , last_name
9 from employees)
10 loop
11 --pipe row(t_rows(i.first_name, i.last_name));
12 l_etab.extend;
13 l_etab(l_etab.last) := t_rows(i.first_name, i.last_name);
14 end loop;
15 return l_etab;
16 end;
17 /
Function created
SQL> select *
2 from table(getenames)
3 where rownum <= 5;
E_NAME E_LNAME
--------------------- ---------------------
Steven King
Neena Kochhar
Lex De Haan
Alexander Hunold
Bruce Ernst
SQL>