Oracle
 sql >> Baza danych >  >> RDS >> Oracle

Alternatywy dla tabel tymczasowych w Oracle

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.



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Nieprawidłowy miesiąc podczas wstawiania danych do Oracle

  2. Miej dane wyjściowe PL/SQL w czasie rzeczywistym

  3. dodawanie klucza podstawowego do widoku sql

  4. Transpozycja wybranych wyników za pomocą Oracle

  5. Oracle APEX — Tabela przeglądowa z kilkoma łączami