sql >> Database >  >> RDS >> Oracle

Alternatieven voor tijdelijke tabellen in Oracle

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.



  1. Hulp nodig bij het ontwerpen van mijn factuur-db-structuur

  2. Kolomkoppen blijven verschijnen in de hele Oracle-uitvoer

  3. geheugenefficiënte ingebouwde SqlAlchemy iterator/generator?

  4. Selecteer * uit tabel waarbij datum =vandaag