gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-03 06:17:14 25 4
gpt4 key购买 nike

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

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com