sql - 如何从存储过程返回多行? (Oracle PL/SQL)

标签 sql oracle plsql

我想创建一个带有一个参数的存储过程,它将根据参数返回不同的记录集。有什么方法可以做到这一点?我可以从普通 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

关于sql - 如何从存储过程返回多行? (Oracle PL/SQL),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/101033/

相关文章:

oracle - 由于 Pragma 自治事务过程检测到死锁

sql - 游标的替代品

mysql - 从特定日期选择唯一记录,不包括以前日期的重复记录

sql - 修改物化 View 查询

php - 为变量设置值

c# - ORA-06550 : line 1, 第 7 列:PLS-00306:参数的数量或类型错误

sql - Oracle sql 嵌套聚合函数

oracle - 在 PLSQL 中使用嵌套函数的正确方法是什么?

sql - 在oracle中加入游标或记录集

sql - Netezza 错误数据分区已满 - 多次调用存储过程时