关于SQL与ORACLE创建本地临时表和全局临时表的方法和区别

SQL Server
 

-- 创建本地临时表.
CREATE TABLE #temp_table_local (
    id INT,
    value VARCHAR(10)
);
go

-- 创建全局临时表.
CREATE TABLE ##temp_table_global (
id INT,
value VARCHAR(10)
);
go



本地临时表,前面一个 #
全局临时表,前面两个 #

临时表在会话中创建,会话结束的时候,数据库自动删除临时表
对于 本地临时表 (#开头的) 其他会话无法访问数据与表结构
对于 全局临时表 (##开头的) 其他会话可以访问数据与表结构
SQL Server会在会话结束以后,自动删除临时表。

------------------------------------------------------------------------------------------------

Oracle

在Oracle中,临时表分为SESSION、TRANSACTION两种,SESSION级的临时表数据在整个SESSION都存在,直到结束此次SESSION;而 TRANSACTION级的临时表数据在TRANACTION结束后消失,即COMMIT/ROLLBACK或结束SESSION都会清除 TRANACTION临时表数据。 

1,创建会话级临时表

  1. create global temporary table temp_tbl(col_a varchar2(30))  on commit preserve rows  

2, 创建事务级临时表 

  1. create global temporary table temp_tbl(col_a varchar2(30))  on commit delete rows  

3、结论 
1、ON COMMIT DELETE ROWS 说明临时表是事务指定,每次提交后ORACLE将截断表(删除全部行)
2、ON COMMIT PRESERVE ROWS 说明临时表是会话指定,当中断会话时ORACLE将截断表。
3、临时表(无论会话级还是事务级)中的数据都是会话隔离的,不同session之间不会共享数据。

4、在存储中使用事务级临时表时,注意commit前删除掉本事务的数据,否则可能会出现数据不断增加的情况(原因尚未搞明白)。

5、 两种临时表的语法:
    create global temporary table 临时表名 on commit preserve|delete rows;

用preserve时就是SESSION级的临时表,

用delete就是TRANSACTION级的临时表。

6、特性和性能(与普通表和视图的比较)
临时表只在当前连接内有效;
临时表不建立索引,所以如果数据量比较大或进行多次查询时,不推荐使用;
数据处理比较复杂的时候时表快,反之视图快点;
在仅仅查询数据的时候建议用游标: open cursor for 'sql clause'; 

posted @ 2022-10-04 00:15  IT情深  阅读(115)  评论(0编辑  收藏  举报