'#Temp'.
如何在Oracle中在存储过程中执行此操作
发布于 2011-09-29 06:27:02
你想要解决的业务问题是什么?在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中真正想使用临时表是非常不寻常的。
发布于 2011-09-29 06:29:15
创建一个全局临时表。
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
https://stackoverflow.com/questions/7598631
复制