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,但不能看到新插入表的任何行。因此,通过自治触发器来获得当前表中最大值、或其它与最新数据相关的操作时行不通的。