基础表(一)临时表

一.临时表

1.什么是临时表

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

2.临时表的特点

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

适用场景:

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

(3)为了让用户表落地                                                                                                                                                                                                                

3.临时表的分类

临时表分为两类:事务临时表 transaction ;会话临时表session

(1)事务临时表

语法:
CREATE GLOBAL TEMPORARY TABLE TABLE_NAME(
CLOUMN1_NAME DATA_TYPE,
...


)ON COMMIT DELETE ROWS;

--由于事务级临时表后跟 on commit delete rows
--所以当事务完成后 表中的数据会被自动删除
--只有在事务开始但未提交时才能查询.

我们向stu_trancsaction 中插入数据 ,并查看在不同事物状态下能否查到数据

当事务开始但未提交时,可以正常查到数据

基础表(一)临时表_第1张图片

 当提交后无法查到

(不论是comiit还是rollback) 

基础表(一)临时表_第2张图片

(2)会话临时表

语法:

CREATE GLOBAL TEMPORARY TABLE TABLE_NAME(
COLUMN_NAME1 DATA_TYPE,
...
)ON COMMIT PRESERVE ROWS;


--会话级临时表在提交后会preserve rows

同理向stu_session中插入数据,并查询不同事物下的状态

在事务开始时可以查到会话级临时表中的数据

基础表(一)临时表_第3张图片

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

基础表(一)临时表_第4张图片

你可能感兴趣的:(数据库)