Oracle临时表的功能与应用

Posted black-start

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle临时表的功能与应用相关的知识,希望对你有一定的参考价值。

什么是临时表,用户做一个操作查询出几百几千条数据,我们可以把数据放在内存中。当有很多用户都这样做,内存空间不足,这个时候就需要把数据保存在磁盘上。对于 oracle 就提供了一种临时表用于存放这些数据。
 
事务级
会话级
 
on commit preserve rows --session 临时表
on commit delete rows --transaction 临时表
 
下面演示创建一个事务级别与会话级别的两个临时表
 
SQL> conn test/test
Connected.
SQL> desc test; 
 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 ID                                                 NUMBER
 NAME                                               VARCHAR2(10)

 

在 sys 下创建 sessione 级别的临时表
SQL> conn / as sysdba
Connected.
SQL> create global temporary table session_test on commit preserve rows as select * from test.test;
Table created.
SQL> commit; Commit complete.

  

on commit preserve rows 表示创建的表是 session 级别,只要用户不退出,临时表一直有效。
 
SQL> select * from session_test;

        ID NAME
---------- ----------
         0 orcl
         1 orcl
         3 orcl
         2 orcl

  

退出并重新进入,并验证表内容是否存在。

SQL> exit
……

SQL> select * from session_test; no rows selected SQL>

  

查看 session 级别的临时表在断开连接后,重新登录查看变为空了。

 

接下来创建事务级别的临时表

SQL> create global temporary table transaction_test on commit delete rows as select * from test.test;

Table created.

  

on commit delete rows 表示创建的表是事务级别,这个临时表的作用范围只在一个事务内有效。

验证事务临时表的作用范围:
虽然是 copy 的 test.test 表,但是依然是没有数据。

SQL> select * from transaction_test;

no rows selected

  

接下来添加数据到事务临时表 transaction_test

SQL> insert into transaction_test select * from test.test; 

4 rows created.

SQL> select * from transaction_test;

        ID NAME
---------- ----------
         0 orcl
         1 orcl
         3 orcl
         2 orcl

  

如上我们将 test.test 表的内容插入到了 transaction_test 表中,然后直接查询,能查到刚刚插入的数据。

接下来提交,并查询。(提交相当于提交事务,也就是一个事务的结束)

SQL> select * from transaction_test;

        ID NAME
---------- ----------
         0 orcl
         1 orcl
         3 orcl
         2 orcl

SQL> commit;

Commit complete.

SQL> select * from transaction_test;

no rows selected

  

由此可见

会话级别的临时表,只要会话不断开,临时表一直有效,会话断开后,临时表内容清空;
事务级别的临时表,只在一个事务内有效,事务提交后,临时表内容清空。

 

以上是关于Oracle临时表的功能与应用的主要内容,如果未能解决你的问题,请参考以下文章

Oracle临时表(Temporary Table)

Oracle临时表(Temporary Table)

SQL Server 表变量和临时表的区别

oracle存储过程中临时表的使用,该怎么处理

Oracle存储过程中临时表的使用技巧

oracle 怎么在存储过程中创建一个临时表,在里面插入数据,再查找这个临时表的所有数据,最后drop这个表。