存储过程支持自治事务

自治事务可以在存储过程中定义,标识符为PRAGMA AUTONOMOUS_TRANSACTION,其余语法与创建存储过程语法相同,示例如下。

  1. --建表
  2. create table t2(a int, b int);
  3. insert into t2 values(1,2);
  4. select * from t2;
  5. --创建包含自治事务的存储过程
  6. CREATE OR REPLACE PROCEDURE autonomous_4(a int, b int) AS
  7. DECLARE
  8. num3 int := a;
  9. num4 int := b;
  10. PRAGMA AUTONOMOUS_TRANSACTION;
  11. BEGIN
  12. insert into t2 values(num3, num4);
  13. END;
  14. /
  15. --创建调用自治事务存储过程的普通存储过程
  16. CREATE OR REPLACE PROCEDURE autonomous_5(a int, b int) AS
  17. DECLARE
  18. BEGIN
  19. insert into t2 values(666, 666);
  20. autonomous_4(a,b);
  21. rollback;
  22. END;
  23. /
  24. --调用普通存储过程
  25. select autonomous_5(11,22);
  26. --查看表结果
  27. select * from t2 order by a;

上述例子,最后在回滚的事务块中执行包含自治事务的存储过程,直接说明了自治事务的特性,即主事务的回滚,不会影响自治事务已经提交的内容。