关于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, 创建事务级临时表 

    • 0
      点赞
    • 3
      收藏
      觉得还不错? 一键收藏
    • 0
      评论
    评论
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

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

    抵扣说明:

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

    余额充值