Jaki problem biznesowy próbujesz rozwiązać? Wyjątkowo rzadko trzeba używać tabel tymczasowych w Oracle. Dlaczego po prostu nie
SELECT *
FROM employees
WHERE id = p_id_passed_in;
W innych bazach danych często tworzysz tabele tymczasowe, ponieważ czytelnicy blokują pisarzy, więc chcesz utworzyć oddzielną kopię danych, aby uniknąć blokowania innych sesji. Jednak w Oracle czytelnicy nigdy nie blokują autorów, więc generalnie nie ma potrzeby zapisywania oddzielnej kopii danych.
W innych bazach danych tworzysz tabele tymczasowe, ponieważ nie chcesz wykonywać brudnych odczytów. Oracle jednak nie pozwala na brudne odczyty. Spójność odczytu wielu wersji oznacza, że Oracle zawsze pokaże dane w postaci, w jakiej istniały podczas uruchamiania zapytania (lub po rozpoczęciu transakcji, jeśli ustawiono poziom izolacji transakcji umożliwiający serializację). Nie ma więc potrzeby tworzenia tymczasowej tabeli, aby uniknąć brudnych odczytów.
Jeśli naprawdę chciałbyś używać tabel tymczasowych w Oracle, nie tworzyłbyś tabeli dynamicznie. Globalną tabelę tymczasową należy utworzyć przed utworzeniem procedury składowanej. Struktura tabeli byłaby widoczna dla wszystkich sesji, ale dane byłyby widoczne tylko dla sesji, która ją wstawiła. Należy wypełnić tabelę tymczasową w procedurze, a następnie wykonać zapytanie do tabeli. Coś jak
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 już powiedziałem, w Oracle byłoby bardzo nietypowe, aby rzeczywiście użyć tabeli tymczasowej.