>데이터 베이스 >MySQL 튜토리얼 >Oracle PL/SQL 저장 프로시저에서 여러 결과 세트를 어떻게 반환할 수 있습니까?

Oracle PL/SQL 저장 프로시저에서 여러 결과 세트를 어떻게 반환할 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-31 08:56:09441검색

How Can I Return Multiple Result Sets from Oracle PL/SQL Stored Procedures?

Oracle PL/SQL의 저장 프로시저에서 여러 레코드 세트 반환

Oracle PL/SQL의 저장 프로시저로 작업할 때 여러 세트 반환 제공된 인수를 기반으로 레코드를 작성하는 것은 일반적인 요구 사항일 수 있습니다. 이를 달성하는 방법은 다음과 같습니다.

결과 세트를 반환하는 함수 생성

결과 세트를 반환하는 함수를 생성하려면 다음과 같은 사용자 정의 유형을 정의할 수 있습니다. 반환하려는 객체를 표현한 다음 함수 내에서 해당 유형의 테이블을 선언합니다. 이 테이블은 함수에 전달된 인수에 따라 동적으로 채워집니다.

다음 예를 고려하세요.

CREATE TYPE emp_obj AS OBJECT (empno NUMBER, ename VARCHAR2(10));
CREATE TYPE emp_tab AS TABLE OF emp_obj;

CREATE OR REPLACE FUNCTION all_emps
RETURN emp_tab
IS
    l_emp_tab emp_tab := emp_tab();
    n INTEGER := 0;
BEGIN
    FOR r IN (SELECT empno, ename FROM emp)
    LOOP
        l_emp_tab.EXTEND;
        n := n + 1;
        l_emp_tab(n) := emp_obj(r.empno, r.ename);
    END LOOP;
    RETURN l_emp_tab;
END;

결과 집합 쿼리

함수가 생성되면 반환된 결과 집합을 마치 테이블인 것처럼 쿼리할 수 있습니다. 예를 들어, 다음 쿼리는 모든 직원을 표시합니다.

SELECT * FROM table (all_emps);

이것은 직원 번호와 이름을 포함하여 모든 직원의 목록을 반환합니다.

일반에서 함수 호출 SQL

일반 SQL에서 함수를 호출하려면 다음을 사용하세요. 구문:

SELECT * FROM all_emps;

함수를 실행하고 결과 세트를 반환합니다.

위 내용은 Oracle PL/SQL 저장 프로시저에서 여러 결과 세트를 어떻게 반환할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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