加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

如何从存储过程返回多行? (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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读