自治事务

本文介绍了SQL自治事务的使用方法及特性,重点解释了自治事务如何处理与父事务之间的数据可见性问题,以及在数据库DML操作中的应用。通过示例演示了如何在自治事务中执行插入操作,并在父事务回滚时,自治事务中数据的状态。强调了自治事务对于维护数据一致性和隔离性的重要作用。

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

1、环境准备

SQL> create table test_a(id number);
CREATE OR REPLACE PROCEDURE p_autonomous_transaction
AS
PRAGMA AUTONOMOUS_TRANSACTION;
BEGIN
 INSERT INTO Test_a VALUES(1);
 COMMIT;
END;
/

2、演示(适用范围,存储过程(可嵌套),匿名块(不能嵌套),包中的procedure,包不能使用)

SQL> begin
  2  p_autonomous_transaction;
  3  rollback;
  4  end;
  5  /
PL/SQL procedure successfully completed
 
SQL> select * from test_a;
       ID
----------
         1

注意:数据库的DML是事务的一部分,如果父事务修改了数据,而在自治事务开始时还没有提交,那么那些修改对子自治事务来说是不可见的。记住,若触发器作为自治事务运行,虽然他仍然可以访问:old,:new,但不能看到新插入表的任何行。因此,通过自治触发器来获得当前表中最大值、或其它与最新数据相关的操作时行不通的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值