집 >데이터 베이스 >MySQL 튜토리얼 >Oracle PL/SQL 저장 프로시저에서 여러 결과 세트를 검색하려면 어떻게 해야 합니까?
Oracle PL/SQL 저장 프로시저에서 여러 결과 세트 검색
Oracle PL/SQL에서 저장 프로시저는 구조화된 캡슐화 방법을 제공합니다. SQL 쿼리 및 데이터베이스 논리. 일반적인 요구 사항 중 하나는 지정된 입력 인수를 기반으로 저장 프로시저에서 여러 레코드 집합을 반환해야 한다는 것입니다. 이는 테이블이나 UDO(사용자 정의 개체) 컬렉션을 반환하는 PL/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에서 결과 집합을 검색하려면 쿼리, 간단히 함수 쿼리:
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 저장 프로시저에서 여러 결과 세트를 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!