Qual è il problema aziendale che stai cercando di risolvere? È eccezionalmente raro che sia necessario utilizzare tabelle temporanee in Oracle. Perché non dovresti semplicemente
SELECT *
FROM employees
WHERE id = p_id_passed_in;
In altri database, spesso si creano tabelle temporanee perché i lettori bloccano i writer, quindi si desidera creare una copia separata dei dati per evitare di bloccare altre sessioni. In Oracle, tuttavia, i lettori non bloccano mai gli autori, quindi generalmente non è necessario salvare una copia separata dei dati.
In altri database, crei tabelle temporanee perché non vuoi eseguire letture sporche. Oracle, tuttavia, non consente letture sporche. La coerenza di lettura multi-versione significa che Oracle ti mostrerà sempre i dati così come esistevano quando è stata avviata la query (o quando è iniziata la transazione se hai impostato un livello di isolamento della transazione serializzabile). Quindi non è necessario creare una tabella temporanea per evitare letture sporche.
Se davvero se volessi utilizzare tabelle temporanee in Oracle, non avresti creato la tabella in modo dinamico. Si creerebbe una tabella temporanea globale prima di creare la stored procedure. La struttura della tabella sarebbe visibile a tutte le sessioni ma i dati sarebbero visibili solo alla sessione che li ha inseriti. Popoli la tabella temporanea nella procedura e quindi esegui una query sulla tabella. Qualcosa come
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.
Come ho detto, tuttavia, sarebbe molto insolito in Oracle voler effettivamente utilizzare una tabella temporanea.