Quel est le problème commercial que vous essayez de résoudre ? Il est exceptionnellement rare que vous ayez besoin d'utiliser des tables temporaires dans Oracle. Pourquoi ne pas simplement
SELECT *
FROM employees
WHERE id = p_id_passed_in;
Dans d'autres bases de données, vous créez souvent des tables temporaires parce que les lecteurs bloquent les écrivains, vous souhaitez donc créer une copie séparée des données afin d'éviter de bloquer d'autres sessions. Dans Oracle, cependant, les lecteurs ne bloquent jamais les rédacteurs, il n'est donc généralement pas nécessaire d'enregistrer une copie séparée des données.
Dans d'autres bases de données, vous créez des tables temporaires parce que vous ne voulez pas faire de lectures erronées. Oracle, cependant, n'autorise pas les lectures sales. La cohérence de lecture multi-version signifie qu'Oracle vous montrera toujours les données telles qu'elles existaient au démarrage de la requête (ou au démarrage de la transaction si vous avez défini un niveau d'isolement de transaction sérialisable). Il n'est donc pas nécessaire de créer une table temporaire pour éviter les lectures erronées.
Si vous vraiment vouliez utiliser des tables temporaires dans Oracle, vous ne créeriez pas la table dynamiquement. Vous devez créer une table temporaire globale avant de créer la procédure stockée. La structure de la table serait visible pour toutes les sessions, mais les données ne seraient visibles que pour la session qui les a insérées. Vous rempliriez la table temporaire dans la procédure, puis interrogeriez la table. Quelque chose comme
CREATE GLOBAL TEMPORARY TABLE temp_emp (
empno number,
ename varchar2(10),
job varchar2(9),
mgr number,
sal number(7,2)
)
ON COMMIT PRESERVE ROWS;
CREATE OR REPLACE PROCEDURE populate_temp_emp
AS
BEGIN
INSERT INTO temp_emp( empno,
ename,
job,
mgr,
sal )
SELECT empno,
ename,
job,
mgr,
sal
FROM emp;
END;
/
SQL> begin
2 populate_temp_emp;
3 end;
4 /
PL/SQL procedure successfully completed.
SQL> select *
2 from temp_emp;
EMPNO ENAME JOB MGR SAL
---------- ---------- --------- ---------- ----------
7623 PAV Dev
7369 smith CLERK 7902 800
7499 ALLEN SALESMAN 7698 1600
7521 WARD SALESMAN 7698 1250
7566 JONES MANAGER 7839 2975
7654 MARTIN SALESMAN 7698 1250
7698 BLAKE MANAGER 7839 2850
7782 CLARK MANAGER 7839 2450
7788 SCOTT ANALYST 7566 3000
7839 KING PRESIDENT 5000
7844 TURNER SALESMAN 7698 1500
7876 ADAMS CLERK 7788 1110
7900 SM0 CLERK 7698 950
7902 FORD ANALYST 7566 3000
7934 MILLER CLERK 7782 1300
1234 BAR
16 rows selected.
Comme je l'ai dit, cependant, il serait très inhabituel dans Oracle de vouloir utiliser une table temporaire.