1、临时表
ORACLE临时表分为基于会话和基于事务的两种临时表
临时表上可以创建索引,临时表上的数据操作不会产生重执行信息
ON COMMIT DELETE ROWS---------------默认 基于事务的 提交后数据清空
ON COMMIT preserve rows------------------基于会话的会话结束数据清空
下面举例创建临时表:
create golbal temporary table test(id number) on commit delete rows;
create golbal temporary table test(id number) on commit preserve rows;
2、临时表详细说明
创建oracle临时表,可以有两种类型的临时表:会话级的临时表和事务级的临时表。
1)会话级的临时表因为这这个临时表中的数据和你的当前会话有关系,当你当前session不退出的情况下,临时表中的数据就还存在,而当你退出当前session的时候,临时表中的数据就全部没有了,当然这个时候你如果以另外一个session登陆的时候是看不到另外一个session中插入到临时表中的数据的。即两个不同的session所插入的数据是互不相干的。当某一个session退出之后临时表中的数据就被截断(truncate table,即数据清空)了。会话级的临时表创建方法:create global temporary table table_name(col1 type1,col2 type2...) on commit preserve rows;举例create global temporary table student(stu_id number(5),class_id number(5),stu_name varchar2(8),stu_memo varchar2(200)) on commit preserve rows ;
2)事务级临时表是指该临时表与事务相关,当进行事务提交或者事务回滚的时候,临时表中的数据将自行被截断,其他的内容和会话级的临时表的一致(包括退出session的时候,事务级的临时表也会被自动截断)。事务级临时表的创建方法:create global temporary table table_name(col1 type1,col2 type2...) on commit delete rows;举例:create global temporary table classes(class_id number(5),class_name varchar2(8),class_memo varchar2(200)) on commit delete rows ;
3)、两种不通类型的临时表的区别:语法上,会话级临时表采用on commit preserve rows而事务级则采用on commit delete rows;用法上,会话级别只有当会话结束临时表中的数据才会被截断,而且事务级临时表则不管是commit、rollback或者是会话结束,临时表中的数据都将被截断。
3、临时表的使用
1)、当某一个sql语句关联的表在2张及以上,并且和一些小表关联。可以采用将大表进行分拆并且得到比较小的结果集合存放在临时表中。
2)、程序执行过程中可能需要存放一些临时的数据,这些数据在整个程序的会话过程中都需要用的等等。