집 >데이터 베이스 >MySQL 튜토리얼 >Oracle PL/SQL 저장 프로시저에서 여러 결과 세트를 어떻게 반환할 수 있습니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!