Voici un exemple de procédure stockée Oracle, dans laquelle la collection de type table est utilisée pour traiter les données.
Traiter les données à l'aide du type de table dans l'exemple de procédure stockée Oracle
Créez les tables suivantes et insérez les données à tester dans votre schéma.
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; Créer une procédure stockée
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 à l'aide du bloc PL/SQL
BEGIN process_bonus; END;
Vérifiez le tableau des bonus pour les données traitées
SELECT * FROM EMP_BONUS;
Sortie :
| EMPNO | BONUS_AMOUNT |
| 7369 | 40 |
| 7499 | 80 |
| 7521 | 62.5 |
Voir aussi :
- Importer un fichier CSV dans Oracle à l'aide d'une procédure stockée
- Renvoyer ResultSet à partir d'une procédure stockée dans Oracle