Oracle
 sql >> Base de données >  >> RDS >> Oracle

Alternatives aux tables temporaires dans Oracle

Quel est le problème commercial que vous essayez de résoudre ? Il est exceptionnellement rare que vous ayez besoin d'utiliser des tables temporaires dans Oracle. Pourquoi ne pas simplement

SELECT *
  FROM employees
 WHERE id = p_id_passed_in;

Dans d'autres bases de données, vous créez souvent des tables temporaires parce que les lecteurs bloquent les écrivains, vous souhaitez donc créer une copie séparée des données afin d'éviter de bloquer d'autres sessions. Dans Oracle, cependant, les lecteurs ne bloquent jamais les rédacteurs, il n'est donc généralement pas nécessaire d'enregistrer une copie séparée des données.

Dans d'autres bases de données, vous créez des tables temporaires parce que vous ne voulez pas faire de lectures erronées. Oracle, cependant, n'autorise pas les lectures sales. La cohérence de lecture multi-version signifie qu'Oracle vous montrera toujours les données telles qu'elles existaient au démarrage de la requête (ou au démarrage de la transaction si vous avez défini un niveau d'isolement de transaction sérialisable). Il n'est donc pas nécessaire de créer une table temporaire pour éviter les lectures erronées.

Si vous vraiment vouliez utiliser des tables temporaires dans Oracle, vous ne créeriez pas la table dynamiquement. Vous devez créer une table temporaire globale avant de créer la procédure stockée. La structure de la table serait visible pour toutes les sessions, mais les données ne seraient visibles que pour la session qui les a insérées. Vous rempliriez la table temporaire dans la procédure, puis interrogeriez la table. Quelque chose comme

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.

Comme je l'ai dit, cependant, il serait très inhabituel dans Oracle de vouloir utiliser une table temporaire.