Oracle子查询临时表

ORACLE 临时表,可以有两种类型的临时表:会话级临时表、事务级临时表。

会话级临时表:

  因为这个临时表中的数据和你的当前会话有关系,当你当前 SESSION 不退出的情况下,临时表中的数据就还存在,而当你退出当前 SESSION 的时候,临时表中的数据就全部没有了,这个时候如果以另外一个 SESSION 登陆的时候是看不到另外一个 SESSION 中的插入到临时表中的数据的。即两个不同的 SESSION 所插入的数据是互不相干的,当某一个 SESSION 退出之后临时表中的数据就会被清空。

--创建会话级临时表
CREATE GLOBAL TEMPORARY TABLE TMP_TABLE(
       ID NUMBER
) ON COMMIT PRESERVE ROWS;

 

事务级临时表:

  指该临时表与事务相关,当进行事务提交或者事务回滚的时候,临时表中的数据将自行被截断,其他的内容和会话级的临时表是一致的(包括退出 SESSION 的时候,事务级的临时表也会被自动截断)。

--创建事务级临时表
CREATE GLOBAL TEMPORARY TABLE TRANSACTION_TABLE(ID NUMBER) ON COMMIT DELETE ROWS;

--进行事务提交COMMIT 或者事务回滚ROLLBACK 时,数据会被自动截断(清除事务操作的数据)
INSERT INTO TRANSACTION_TABLE(ID) VALUES(1111);
COMMIT;
ROLLBACK;

 

临时表

-- 语法结构:WITH... AS..语法结构
/*
  WITH 临时表名1 AS
  (SELECT 查询语句),
  临时表2 AS
  (SELECT 查询语句),
  临时表3 AS
  (SELECT 查询语句)
  ...
  SELECT 查询语句;
*/

WITH TMP_A AS
(SELECT MAX(T.SAL) MAX_SAL FROM EMP T) --把查询结构当作临时表
SELECT B.*
  FROM EMP B,TMP_A C
 WHERE B.SAL = C.MAX_SAL;

 

 

总结:

1、两种临时表的异同:
相同点:
两种表都不能永久的保存记录,都是用临时表空间。
不同点:
会话级临时表只有当会话结束时,临时表中的数据才会被截断;而事务级临时表则不管是COMMIT、ROLLBACK 或者是会话结束,临时表中的数据都将被截断。

2、临时表的使用场景:
把复杂的逻辑拆分开来,用临时表储存中间结果,以方便后面的逻辑处理。程序执行过程中可能需要存放一些临时的数据,这些数据在整个程序的会话过程中都需要用到等。

posted @ 2020-10-15 11:16  小碗吃不胖的  阅读(1137)  评论(0编辑  收藏  举报