Oracle
 sql >> Base de Dados >  >> RDS >> Oracle

Alternativas para tabelas temporárias no Oracle


Qual é o problema de negócios que você está tentando resolver? É excepcionalmente raro que você precise usar tabelas temporárias no Oracle. Por que você simplesmente não
SELECT *
  FROM employees
 WHERE id = p_id_passed_in;

Em outros bancos de dados, você geralmente cria tabelas temporárias porque os leitores bloqueiam os gravadores, portanto, você deseja criar uma cópia separada dos dados para evitar o bloqueio de outras sessões. No Oracle, no entanto, os leitores nunca bloqueiam os escritores, portanto, geralmente não há necessidade de salvar uma cópia separada dos dados.

Em outros bancos de dados, você cria tabelas temporárias porque não deseja fazer leituras sujas. O Oracle, no entanto, não permite leituras sujas. A consistência de leitura de várias versões significa que o Oracle sempre mostrará os dados como existiam quando a consulta foi iniciada (ou quando a transação foi iniciada, se você definiu um nível de isolamento de transação como serializável). Portanto, não há necessidade de criar uma tabela temporária para evitar leituras sujas.

Se você realmente quisesse usar tabelas temporárias no Oracle, você não criaria a tabela dinamicamente. Você criaria uma tabela temporária global antes de criar o procedimento armazenado. A estrutura da tabela seria visível para todas as sessões, mas os dados seriam visíveis apenas para a sessão que a inseriu. Você preencheria a tabela temporária no procedimento e, em seguida, consultaria a tabela. Algo como
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.

Como eu disse, no entanto, seria muito incomum no Oracle realmente querer usar uma tabela temporária.