>데이터 베이스 >MySQL 튜토리얼 >Oracle PL/SQL 저장 프로시저에서 여러 결과 세트를 검색하려면 어떻게 해야 합니까?

Oracle PL/SQL 저장 프로시저에서 여러 결과 세트를 검색하려면 어떻게 해야 합니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-26 16:32:14549검색

How Can I Retrieve Multiple Result Sets from an Oracle PL/SQL Stored Procedure?

Oracle PL/SQL 저장 프로시저에서 여러 결과 세트 검색

Oracle PL/SQL에서 저장 프로시저는 구조화된 캡슐화 방법을 제공합니다. SQL 쿼리 및 데이터베이스 논리. 일반적인 요구 사항 중 하나는 지정된 입력 인수를 기반으로 저장 프로시저에서 여러 레코드 집합을 반환해야 한다는 것입니다. 이는 테이블이나 UDO(사용자 정의 개체) 컬렉션을 반환하는 PL/SQL 함수를 생성하여 수행할 수 있습니다.

결과 집합을 반환하는 함수를 생성하려면 다음 단계를 따르세요.

  1. 데이터를 보관할 테이블 유형이나 컬렉션 유형을 정의합니다.
  2. 인수를 받아들이고 테이블의 로컬 변수를 선언하는 함수를 만듭니다. 지정된 데이터 유형.
  3. 데이터베이스의 레코드를 통해 커서나 루프를 실행하여 변수를 채우고 그에 따라 크기를 확장합니다.
  4. 결과 세트가 포함된 데이터 구조를 반환합니다.

다음은 테이블 유형을 사용하는 예입니다.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.