Oracle中临时表的替代方案

时间:2011-09-29 14:12:33

标签: oracle plsql

  1. 在存储过程中创建一个临时表,比如'#Temp'。
  2. 使用select语句将值插入'Temp'表中,例如。插入#Temp从员工中选择*。
  3. 现在从此Temp表中提取数据,例如。从#Temp中选择*,其中#Temp.Id = @id&等等。
  4. 如何在存储过程中的Oracle 中执行此操作?

2 个答案:

答案 0 :(得分:15)

您要解决的业务问题是什么?您需要在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 :(得分:2)

创建一个全局临时表。

CREATE GLOBAL TEMPORARY TABLE <your_table>
ON COMMIT PRESERVE ROWS   # If needed.  Depends on your needs.
AS SELECT <your_select_query>;

然后,您可以根据需要在表格中选择。

http://www.oracle-base.com/articles/8i/TemporaryTables.php

http://asktom.oracle.com/pls/asktom/f?p=100:11:0::::P11_QUESTION_ID:15826034070548

相关问题