前言:
今天小伙伴们对“oracle事务控制语言”大体比较关注,咱们都想要学习一些“oracle事务控制语言”的相关内容。那么小编同时在网络上收集了一些关于“oracle事务控制语言””的相关文章,希望我们能喜欢,你们一起来学习一下吧!【本文详细介绍了Oracle数据库扩展语言PL/SQL中自治事务的基本概念和使用方法,欢迎读者朋友们阅读、转发和收藏!】
在基于低版本的 Oracle 执行当前一个由多个 DML 组成的 transaction( 事务 ) 时 ,如果 为每一步 DML 记录一些信息到跟踪表中 , 由于事务的原子性 , 这些跟踪信息的提交将决定于主事务的 commit 或 rollback. 这样一来写程序的难度就增大了 , 程序员不得不把这些跟踪信息记录到类似数组的结构中 , 然后在主事务结束后把它们存入跟踪表。
为解决这个问题, ORACLE8i 新增了 AUTONOMOUS TRANSACTION( 自治事务,以下 AT) 。
AT 是由主事务 ( 以下 MT) 调用但是独立于它的事务。在 AT 被调用执行时, MT 被挂起,在 AT 内部,一系列的 DML 可以被执行并且 commit 或 rollback.
注意由于 AT 的独立性,它的 commit 和 rollback 并不影响 MT 的执行效果。在 AT 执行结束后,主事务获得控制权,又可以继续执行了。
实现 AT 的定义只需下列 PL/SQL 的声明部分加上 PRAGMAAUTONOMOUS_TRANSACTION 就可以了。
可以加自治事务的有:
1 . 顶级的匿名 PL/SQL 块
2 . Functions 或 Procedure (独立声明或声明在 package 中都可)
3 . SQL Object Type 的方法
4 . 触发器。
比如:
在一个独立的 procedure 中声明 AT
CREATE OR REPLACE PROCEDURELog_error(error_msg IN VARCHAR2(100))ISPRAGMA AUTONOMOUS_TRANSACTION;BEGINInsert into Error_log values ( sysdate,error_msg);COMMIT;END;
运用 AT 时 , 有一些注意事项 , 简单列举如下 :
1. 在匿名 PL/SQL 块中 , 只有顶级的匿名 PL/SQL 块可以被设为 AT
2. 如果 AT 试图访问被 MT 控制的资源 , 可能有 deadlock 发生 .
3. Package 不能被声明为 AT, 只有 package 所拥有的 function 和 procedure 才能声明为 AT
4. AT 程序必须以 commit 或 rollback 结尾 , 否则会产生 Oracle 错误 ORA-06519: active autonomous transaction detected and rolled back
在日志记录,或者是重试计数等这样的场景中使用自治事物,可不用考虑主事物是否提交
标签: #oracle事务控制语言