Wat is het zakelijke probleem dat u probeert op te lossen? Het komt zelden voor dat u tijdelijke tabellen in Oracle moet gebruiken. Waarom zou je niet gewoon
SELECT *
FROM employees
WHERE id = p_id_passed_in;
In andere databases maakt u vaak tijdelijke tabellen omdat lezers schrijvers blokkeren, dus u wilt een aparte kopie van de gegevens maken om te voorkomen dat andere sessies worden geblokkeerd. In Oracle blokkeren lezers echter nooit schrijvers, dus het is over het algemeen niet nodig om een aparte kopie van de gegevens op te slaan.
In andere databases maakt u tijdelijke tabellen omdat u geen vuile reads wilt doen. Oracle staat echter geen dirty reads toe. Leesconsistentie met meerdere versies betekent dat Oracle u altijd de gegevens laat zien zoals deze bestonden toen de query werd gestart (of toen de transactie werd gestart als u een transactie-isolatieniveau van serializable hebt ingesteld). Het is dus niet nodig om een tijdelijke tabel te maken om vuil lezen te voorkomen.
Als je echt tijdelijke tabellen in Oracle wilde gebruiken, zou u de tabel niet dynamisch maken. U zou een globale tijdelijke tabel maken voordat u de opgeslagen procedure maakte. De tabelstructuur zou zichtbaar zijn voor alle sessies, maar de gegevens zouden alleen zichtbaar zijn voor de sessie die deze heeft ingevoegd. U zou de tijdelijke tabel in de procedure vullen en vervolgens de tabel opvragen. Iets als
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.
Zoals ik al zei, zou het in Oracle echter zeer ongebruikelijk zijn om een tijdelijke tabel te willen gebruiken.