Poniżej znajduje się przykład procedury składowanej Oracle, w której do przetwarzania danych używana jest kolekcja typów tabeli.
Przetwarzaj dane przy użyciu typu tabeli w przykładzie procedury składowanej Oracle
Utwórz poniższe tabele i wstaw dane do przetestowania w swoim schemacie.
CREATE TABLE EMP ( EMPNO NUMBER(4), ENAME VARCHAR2(10 BYTE), JOB VARCHAR2(9 BYTE), MGR NUMBER(4), HIREDATE DATE, SAL NUMBER(7,2), COMM NUMBER(7,2), DEPTNO NUMBER(2) ) /
CREATE TABLE EMP_BONUS ( EMPNO NUMBER(4), BONUS_AMOUNT NUMBER ) /
SET DEFINE OFF;
Insert into EMP
(EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, DEPTNO)
Values
(7369, 'SMITH', 'CLERK', 7902,
TO_DATE('12/17/1980 00:00:00', 'MM/DD/YYYY HH24:MI:SS'), 800, 20);
Insert into EMP
(EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
Values
(7499, 'ALLEN', 'SALESMAN', 7698,
TO_DATE('02/20/1981 00:00:00', 'MM/DD/YYYY HH24:MI:SS'), 1600, 300, 30);
Insert into EMP
(EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
Values
(7521, 'WARD', 'SALESMAN', 7698,
TO_DATE('02/22/1981 00:00:00', 'MM/DD/YYYY HH24:MI:SS'), 1250, 500, 30);
COMMIT; Utwórz zapisaną procedurę
CREATE OR REPLACE PROCEDURE process_bonus IS CURSOR c_emp IS SELECT EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO FROM emp; /* declare table type in the procedure declare section as below */ TYPE t_emp_table IS TABLE OF emp%ROWTYPE INDEX BY BINARY_INTEGER; t_emp t_emp_table; BEGIN OPEN c_emp; /* fetch cursor data into table type using bulk collect */ FETCH c_emp BULK COLLECT INTO t_emp; CLOSE c_emp; FOR i IN t_emp.FIRST .. t_emp.LAST LOOP /* insert 5% bonus of employee's salary into emp_bonus table */ INSERT INTO emp_bonus (empno, bonus_amount) VALUES (t_emp (i).empno, t_emp (i).sal * 5 / 100); END LOOP; COMMIT; END;
Test przy użyciu bloku PL/SQL
BEGIN process_bonus; END;
Sprawdź tabelę premii dla przetworzonych danych
SELECT * FROM EMP_BONUS;
Wyjście:
| PRACA | BONUS_AMOUNT |
| 7369 | 40 |
| 7499 | 80 |
| 7521 | 62,5 |
Zobacz też:
- Importuj plik CSV do Oracle za pomocą procedury przechowywanej
- Zwróć zestaw wyników z procedury przechowywanej w Oracle