Jaký je obchodní problém, který se snažíte vyřešit? Je výjimečně vzácné, že potřebujete v Oracle používat dočasné tabulky. Proč byste jednoduše
SELECT *
FROM employees
WHERE id = p_id_passed_in;
V jiných databázích často vytváříte dočasné tabulky, protože čtečky blokují zapisovače, takže chcete vytvořit samostatnou kopii dat, abyste se vyhnuli blokování dalších relací. V Oracle však čtečky nikdy neblokují zapisovače, takže obecně není potřeba ukládat samostatnou kopii dat.
V jiných databázích vytváříte dočasné tabulky, protože nechcete provádět nečisté čtení. Oracle však nepovoluje nečisté čtení. Konzistence čtení ve více verzích znamená, že vám Oracle vždy zobrazí data tak, jak existovala při spuštění dotazu (nebo při zahájení transakce, pokud jste nastavili úroveň izolace transakcí na serializovatelnou). Není tedy potřeba vytvářet dočasnou tabulku, abyste se vyhnuli nečistým čtením.
Pokud opravdu chtěli použít dočasné tabulky v Oracle, nevytvářeli byste tabulku dynamicky. Před vytvořením uložené procedury byste vytvořili globální dočasnou tabulku. Struktura tabulky by byla viditelná pro všechny relace, ale data by byla viditelná pouze pro relaci, která je vložila. V proceduře byste naplnili dočasnou tabulku a poté se dotázali na tabulku. Něco jako
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.
Jak jsem však řekl, v Oracle by bylo velmi neobvyklé chtít skutečně používat dočasnou tabulku.