函数支持自治事务

自治事务可以在函数中定义,标识符为PRAGMA AUTONOMOUS_TRANSACTION,其余语法与函数语法相同,示例如下。

  1. create table t4(a int, b int, c text);
  2. CREATE OR REPLACE function autonomous_32(a int ,b int ,c text) RETURN int AS
  3. DECLARE
  4. PRAGMA AUTONOMOUS_TRANSACTION;
  5. BEGIN
  6. insert into t4 values(a, b, c);
  7. return 1;
  8. END;
  9. /
  10. CREATE OR REPLACE function autonomous_33(num1 int) RETURN int AS
  11. DECLARE
  12. num3 int := 220;
  13. tmp int;
  14. PRAGMA AUTONOMOUS_TRANSACTION;
  15. BEGIN
  16. num3 := num3/num1;
  17. return num3;
  18. EXCEPTION
  19. WHEN division_by_zero THEN
  20. select autonomous_32(num3, num1, sqlerrm) into tmp;
  21. return 0;
  22. END;
  23. /
  24. select autonomous_33(0);
  25. select * from t4;