Oracle
 sql >> база данни >  >> RDS >> Oracle

Алтернативи за временни таблици в Oracle

Какъв е бизнес проблемът, който се опитвате да разрешите? Изключително рядко се налага да използвате временни таблици в Oracle. Защо просто не

SELECT *
  FROM employees
 WHERE id = p_id_passed_in;

В други бази данни често създавате временни таблици, защото четците блокират записващите, така че искате да създадете отделно копие на данните, за да избегнете блокирането на други сесии. В Oracle обаче четците никога не блокират писатели, така че обикновено няма нужда да се записва отделно копие на данните.

В други бази данни създавате временни таблици, защото не искате да правите мръсни четения. Oracle обаче не позволява мръсни четения. Съгласуваност при четене на много версии означава, че Oracle винаги ще ви показва данните така, както са съществували, когато заявката е стартирана (или когато транзакцията е започнала, ако сте задали ниво на изолация на транзакция за сериализуемо). Така че няма нужда да създавате временна таблица, за да избегнете мръсни четения.

Ако наистина искате да използвате временни таблици в Oracle, няма да създадете таблицата динамично. Ще създадете глобална временна таблица, преди да създадете съхранената процедура. Структурата на таблицата ще бъде видима за всички сесии, но данните ще бъдат видими само за сесията, която ги е вмъкнала. Ще попълните временната таблица в процедурата и след това ще направите заявка към таблицата. Нещо като

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.

Както казах обаче, би било много необичайно в Oracle всъщност да искате да използвате временна таблица.



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Променливи на Oracle

  2. Производителност:rank() срещу подзаявка. Подзаявката има по-ниска цена?

  3. Как да напиша включена рекурсивна подзаявка в sqlplus с множество таблици за проследяване на възли?

  4. Как да изключа уикендите в SQL?

  5. Как да стартирате sql скриптове от pl sql процедура