创建事务级临时表或者会话级临时表,并测试什么情况下临时表的数据会消失

创建事务级临时表或者会话级临时表,并测试什么情况下临时表的数据会消失

一.临时表

1.什么是临时表

用于保存回话或者事务产生的中间结果,只对当前会话可见,其它任何会话无法查询临时创建的表
2.临时表的特点

(1)oracle为了保证多个用户操作的并发性和独立性,对一张表读取的不同用户,oracle为每个用户分配了独立的临时段(temp segment),这样就避免了多个用户在操作时同一张表时产生交叉.

适用场景:

(2) 当某些数据需要被频繁操作并且会产生不需要保存的中间数据时,需要建立临时表

(3)为了让用户表落地

3.临时表的分类

临时表分为两类:事务临时表 transaction ;会话临时表session
(1)事务临时表
事务级临时表如果进行了TCL(commit, rollback)的操作,数据就被清空

语法:
CREATE GLOBAL TEMPORARY TABLE TABLE_NAME(
CLOUMN1_NAME DATA_TYPE,
...
 
 
)ON COMMIT DELETE ROWS;
 
--由于事务级临时表后跟 on commit delete rows
--所以当事务完成后 表中的数据会被自动删除
--只有在事务开始但未提交时才能查询.

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

我们向S1 中插入数据 ,并查看在不同事物状态下能否查到数据
当事务开始但未提交时,可以正常查到数据

(2)会话临时表
会话临时表只在当前会话(连接)内可用,且在当前会话结束(断开数据库连接)后就会销毁;当切换或者关闭了当前的窗口,数据就清空销毁。

语法:
 
CREATE GLOBAL TEMPORARY TABLE TABLE_NAME(
COLUMN_NAME1 DATA_TYPE,
...
)ON COMMIT PRESERVE ROWS;
 
 
--会话级临时表在提交后会preserve rows

向S2中插入数据,并查询不同事物下的状态
在事务开始时可以查到会话级临时表中的数据
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在事务结束时,若选择commit则临时表中的数据会被保留,否则被清除

两中类型临时表数据消失的区别
会话级临时表采用on commit preserve rows;而事务级则采用on commit delete rows;用法上,会话级别只有当会话结束临时表中的数据才会被截断,而且事务级临时表则不管是commit、rollback或者是会话结束,临时表中的数据都将被截断
在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值