什么是你试图解决的商业问题? 非常罕见的是,你需要在Oracle中使用临时表格。 为什么要 t你,只是
SELECT *
FROM employees
WHERE id = p_id_passed_in;
在其他数据库中,由于读者将编组作者,你往往制作临时表格,因此希望制作一份单独的数据副本,以避免阻碍任何其他会议。 然而,在Oracle,读者从来不阻挡作者,因此,一般没有必要从数据单上提取数据副本。
在其他数据库中,你创建临时表格是因为你不想干.。 但是,Oracle不允许 reads脏。 多变式改为一致性意味着,Oracle将始终显示在查询开始时(或者如果你确定可序列号的交易孤立程度,交易开始时)存在的数据。 因此,没有必要设立一个临时表格,以避免拖延。
如果你really希望用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.
然而,正如我所说的那样,甲骨文中实际上想要使用临时表格是非常罕见的。