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,但不能看到新插入表的任何行。因此,通过自治触发器来获得当前表中最大值、或其它与最新数据相关的操作时行不通的。
本文介绍了SQL自治事务的使用方法及特性,重点解释了自治事务如何处理与父事务之间的数据可见性问题,以及在数据库DML操作中的应用。通过示例演示了如何在自治事务中执行插入操作,并在父事务回滚时,自治事务中数据的状态。强调了自治事务对于维护数据一致性和隔离性的重要作用。
1861

被折叠的 条评论
为什么被折叠?



