如何从存储过程返回多行? (Oracle PL/SQL)
发布时间:2020-12-12 14:29:10 所属栏目:百科 来源:网络整理
导读:我想创建一个存储过程,其中一个参数将根据参数返回不同的记录集。什么是这样做的方式?我可以从纯SQL来调用它吗? 这里是如何构建一个函数,返回一个结果集,可以查询,就像它是一个表: SQL create type emp_obj is object (empno number,ename varchar2(1
我想创建一个存储过程,其中一个参数将根据参数返回不同的记录集。什么是这样做的方式?我可以从纯SQL来调用它吗?
这里是如何构建一个函数,返回一个结果集,可以查询,就像它是一个表:
SQL> create type emp_obj is object (empno number,ename varchar2(10)); 2 / Type created. SQL> create type emp_tab is table of emp_obj; 2 / Type created. SQL> create or replace function all_emps return emp_tab 2 is 3 l_emp_tab emp_tab := emp_tab(); 4 n integer := 0; 5 begin 6 for r in (select empno,ename from emp) 7 loop 8 l_emp_tab.extend; 9 n := n + 1; 10 l_emp_tab(n) := emp_obj(r.empno,r.ename); 11 end loop; 12 return l_emp_tab; 13 end; 14 / Function created. SQL> select * from table (all_emps); EMPNO ENAME ---------- ---------- 7369 SMITH 7499 ALLEN 7521 WARD 7566 JONES 7654 MARTIN 7698 BLAKE 7782 CLARK 7788 SCOTT 7839 KING 7844 TURNER 7902 FORD 7934 MILLER (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |