Oracle
 sql >> Datenbank >  >> RDS >> Oracle

Alternativen für temporäre Tabellen in Oracle

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.