Oracle 临时表操作

本文详细介绍了两种不同类型的全局临时表(GTT)在Oracle数据库中的使用方法:一种是在提交后保留行(ON COMMIT PRESERVE ROWS),另一种是在提交后删除行(ON COMMIT DELETE ROWS)。通过具体的SQL语句演示了如何创建、插入数据、提交、回滚以及最终删除这些临时表。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

--SESSION 结束就 DELETE
CREATE GLOBAL TEMPORARY TABLE tmp_foo(
    id NUMBER(10) NOT NULL,
    name VARCHAR2(32) NOT NULL,
    CONSTRAINT pk_foo_id PRIMARY KEY(id)
) ON COMMIT PRESERVE ROWS;                  --注意此处

--操作 1
INSERT INTO tmp_foo VALUES(1,'kerry');
SELECT * FROM tmp_foo;
--操作 2
COMMIT;
INSERT INTO tmp_foo VALUES(2,'rouce');
--操作 3
ROLLBACK;
SELECT * FROM tmp_foo;
--操作 4
COMMIT;
TRUNCATE TABLE tmp_foo;
--操作 5
DROP TABLE tmp_foo;
--COMMIT 就 DELETE
CREATE GLOBAL TEMPORARY TABLE tmp_bar(
    id NUMBER(10) NOT NULL,
    name VARCHAR2(32) NOT NULL,
    CONSTRAINT pk_bar_id PRIMARY KEY(id)
) ON COMMIT DELETE ROWS;                    --注意此处

--操作 1
INSERT INTO tmp_bar VALUES(1,'kerry');
SELECT * FROM tmp_bar;
--操作 2
COMMIT;
SELECT * FROM tmp_bar;
--操作 3
TRUNCATE TABLE tmp_bar;
--操作 4
DROP TABLE tmp_bar;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值