Welches Geschäftsproblem möchten Sie lösen? Es kommt äußerst selten vor, dass Sie temporäre Tabellen in Oracle verwenden müssen. Warum würden Sie nicht einfach
SELECT *
FROM employees
WHERE id = p_id_passed_in;
In anderen Datenbanken erstellen Sie häufig temporäre Tabellen, weil Reader Writer blockieren, sodass Sie eine separate Kopie der Daten erstellen möchten, um zu vermeiden, dass andere Sitzungen blockiert werden. In Oracle blockieren Leser jedoch niemals Schreiber, sodass es im Allgemeinen nicht erforderlich ist, eine separate Kopie der Daten zu speichern.
In anderen Datenbanken erstellen Sie temporäre Tabellen, weil Sie keine schmutzigen Lesevorgänge durchführen möchten. Oracle erlaubt jedoch keine Dirty Reads. Multiversions-Lesekonsistenz bedeutet, dass Oracle Ihnen die Daten immer so anzeigt, wie sie zum Zeitpunkt des Starts der Abfrage vorlagen (oder als die Transaktion gestartet wurde, wenn Sie eine Transaktionsisolationsstufe auf serialisierbar eingestellt haben). Es besteht also keine Notwendigkeit, eine temporäre Tabelle zu erstellen, um Dirty Reads zu vermeiden.
Wenn Sie wirklich Wenn Sie temporäre Tabellen in Oracle verwenden möchten, würden Sie die Tabelle nicht dynamisch erstellen. Sie würden eine globale temporäre Tabelle erstellen, bevor Sie die gespeicherte Prozedur erstellen. Die Tabellenstruktur wäre für alle Sitzungen sichtbar, aber die Daten wären nur für die Sitzung sichtbar, die sie eingefügt hat. Sie würden die temporäre Tabelle in der Prozedur füllen und dann die Tabelle abfragen. So etwas wie
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.
Aber wie gesagt, es wäre in Oracle sehr ungewöhnlich, tatsächlich eine temporäre Tabelle verwenden zu wollen.