Oracle
 sql >> Database >  >> RDS >> Oracle

Alternative per le tabelle temporanee in Oracle

Qual è il problema aziendale che stai cercando di risolvere? È eccezionalmente raro che sia necessario utilizzare tabelle temporanee in Oracle. Perché non dovresti semplicemente

SELECT *
  FROM employees
 WHERE id = p_id_passed_in;

In altri database, spesso si creano tabelle temporanee perché i lettori bloccano i writer, quindi si desidera creare una copia separata dei dati per evitare di bloccare altre sessioni. In Oracle, tuttavia, i lettori non bloccano mai gli autori, quindi generalmente non è necessario salvare una copia separata dei dati.

In altri database, crei tabelle temporanee perché non vuoi eseguire letture sporche. Oracle, tuttavia, non consente letture sporche. La coerenza di lettura multi-versione significa che Oracle ti mostrerà sempre i dati così come esistevano quando è stata avviata la query (o quando è iniziata la transazione se hai impostato un livello di isolamento della transazione serializzabile). Quindi non è necessario creare una tabella temporanea per evitare letture sporche.

Se davvero se volessi utilizzare tabelle temporanee in Oracle, non avresti creato la tabella in modo dinamico. Si creerebbe una tabella temporanea globale prima di creare la stored procedure. La struttura della tabella sarebbe visibile a tutte le sessioni ma i dati sarebbero visibili solo alla sessione che li ha inseriti. Popoli la tabella temporanea nella procedura e quindi esegui una query sulla tabella. Qualcosa come

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.

Come ho detto, tuttavia, sarebbe molto insolito in Oracle voler effettivamente utilizzare una tabella temporanea.