AUTONOMOUS TRANSACTION(自治事务)的介绍
  在基于低版本的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的声明部分加上PRAGMA AUTONOMOUS_TRANSACTION 就可以了。
  1. 顶级的匿名PL/SQL块
  2. Functions 或 Procedure(独立声明或声明在package中都可)
  3. SQL Object Type的方法
  4. 触发器。
  
  
  比如:
  在一个独立的procedure中声明AT
  CREATE OR REPLACE PROCEDURE
   Log_error(error_msg IN VARCHAR2(100))
  IS
   PRAGMA AUTONOMOUS_TRANSACTION;
  BEGIN
   Insert into Error_log values ( sysdate,error_msg);
   COMMIT;
  END;
  下面我们来看一个例子,(win2000 advanced server + oracle8.1.6 , connect as scott)
  建立一个表:
  create table msg (msg varchar2(120));
  首先,用普通的事务写个匿名PL/SQL块:
  declare
   cnt number := -1; --} Global variables
   procedure local is
   begin
   select count(*) into cnt from msg;
   dbms_output.put_line('local: # of rows is '||cnt);
  
   insert into msg values ('New Record');
   commit;
   end;
  
  
   begin
   delete from msg ;
   commit;
   insert into msg values ('Row 1');
   local;
   select count(*) into cnt from msg;
   dbms_output.put_line('main: # of rows is '||cnt);
   rollback;
   local;
   insert into msg values ('Row 2');
   commit;
   local;
   select count(*) into cnt from msg;
   dbms_output.put_line('main: # of rows is '||cnt);
   end;
  运行结果(注意打开serveroutput)
  local: # of rows is 1 -> 子程序local中可以’看到’主匿名块中的uncommitted记录
  main: # of rows is 2 -> 主匿名块可以’看到’2条记录(它们都是被local commit掉的)
  local: # of rows is 2 -> 子程序local首先’看到’2条记录,然后又commit了第三条记录
  local: # of rows is 4 -> 子程序local又’看到’了新增加的记录(它们都是被local commit掉的),然后又commit了第五条记录
  main: # of rows is 5 -> 主匿名块最后’看到’了所有的记录.
  
  从这个例子中,我们看到COMMIT和ROLLBACK的位置无论是在主匿名块中或者在子程序中,都会影响到整个当前事务.
  
  
  现在用AT改写一下匿名块中的procedure local:
  ...
   procedure local is
   pragma AUTONOMOUS_TRANSACTION;
   begin
  ...
  重新运行(注意打开serveroutput)
  local: # of rows is 0 -> 子程序local中无法可以’看到’主匿名块中的uncommitted记录 (因为它是独立的)
  main: # of rows is 2 -> 主匿名块可以’看到’2条记录,但只有一条是被commited.
  local: # of rows is 1 -> 子程序local中可以’看到’它前一次commit的记录,但是主匿名块中的记录已经被提前rollback了
  local: # of rows is 3 -> 子程序local 中可以’看到’3条记录包括主匿名块commit的记录
  main: # of rows is 4 ->主匿名块最后’看到’了所有的记录.
  很明显,AT是独立的,在它执行时,MT被暂停了. AT的COMMIT,ROLLBACK并不影响MT的执行.
  运用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
  在程序开发时,如果充分运用AUTONOMOUS TRANSACTION的特性,一定能取得事倍功半的效果.

关于Oracle AUTONOMOUS TRANSACTION(自治事务)的介绍的更多相关文章

  1. (转)关于Oracle AUTONOMOUS TRANSACTION(自治事务)的介绍

    AUTONOMOUS TRANSACTION(自治事务)的介绍 在基于低版本的ORACLE做一些项目的过程中,有时会遇到一些头疼的问题,比如想在执行当前一个由多个DML组成的transaction(事 ...

  2. Oracle与SQL自治事务

    自治事务 自治事务是独立的事务操作,如果考虑到事务回滚,必须单独写成一个触发器来完成, 一个事务A在另一个事务B内被调用,那个事务A是自治事务,自治事务A执行过程中会脱离其session内未执行完毕的 ...

  3. ORACLE PRAGMA AUTONOMOUS_TRANSACTION 自治事务 单独提交某一段操作

    个人使用示例: CREATE OR REPLACE PROCEDURE logs(p_remark VARCHAR2, p_log CLOB) AS PRAGMA AUTONOMOUS_TRANSAC ...

  4. ORACLE触发器的自治事务的注意事项

    直接上代码: Create OR replace Trigger TR_ROBXMX_CLDJBHHX After INSERT OR UPDATE OR DELETE ON ROBXMX1 --要监 ...

  5. Oracle - 自治事务autonomous transaction

    自治事务 - autonomous transaction 在Oracle数据库中,有时候我们会希望记录一个过程或者函数的运行日志,不管正常运行结束还是触发异常结束,都要记录. 正常结束的没有问题,但 ...

  6. oracle 自治事物 -- autonomous transaction

    一 使用规则 : 在begin 之前申明  : PRAGMA AUTONOMOUS_TRANSACTION; 二 使用理解:autonomous transaction 是一个独立的事务,这一点是理解 ...

  7. Oracle Autonomous Transactions(自治事务)

    Oracle Autonomous Transactions Autonomous transactions allow you to leave the context of the calling ...

  8. [转]了解oracle自治事务

    http://blog.csdn.net/indexman/article/details/7799862 1.什么是Oracle自治事务 在官方文档中,是这样的定义的“Autonomous tran ...

  9. Oracle EBS 自治事务

    自治事务程序主要是自主性,那就是,独立于主要的事务.之所以独立,或者提交之后会影响其他事务处理,本质在于它本身符合编译指令的规则,也就是说它属于在编译阶段就执行的指令,而不是在运行阶段执行的. 当自治 ...

随机推荐

  1. Lind.DDD.UoW~方法回调完成原子化操作

    回到目录 本文来自于实践中的不足 在最近开始过程中,遇到了一个问题,之前设计的工作单元UoW只支持Insert,Update,Delete三种操作,即开发人员可以将以上三种操作同时扔进工作单元,由工作 ...

  2. Ajax的核心对象创建步骤

    * Ajax具有核心对象 * XMLHttpRequest对象 * 如何创建XMLHttpRequest对象 function getXhr(){ // 声明XMLHttpRequest对象 var ...

  3. 【Swift 2.1】为 UIView 添加点击事件和点击效果

    前言 UIView 不像 UIButton 加了点击事件就会有点击效果,体验要差不少,这里分别通过自定义和扩展来实现类似 UIButton 的效果. 声明 欢迎转载,但请保留文章原始出处:) 博客园: ...

  4. iOS RESideMenu 侧滑 第三方类库

    下载地址:https://github.com/romaonthego/RESideMenu 效果如下:官方案例 自己的实现效果 具体代码下: AppDelegate.m文件中 - (BOOL)app ...

  5. 关于watir-webdriver中文乱码问题

    require 'watir-webdriver' require 'iconv' cov = Iconv.new( 'gbk', 'utf-8') b = Watir::Browser.new b. ...

  6. 解决idea中执行maven命令失败的问题

    1.问题描述 如上图所示,在使用idea 里的maven命令执行项目打包时,有时候会报如下一个错误. -Dmaven.multiModuleProjectDirectory system proper ...

  7. Play Framework 完整实现一个APP(七)

    1.添加验证码 Application Controller添加captcha() public static void captcha() { Images.Captcha captcha = Im ...

  8. Linux命令学习总结:last

    命令简介:     该命令用来列出目前与过去登录系统的用户相关信息.指令英文原义:show listing of last logged in users 执行权限 :有些需要特殊权限 指令所在路径: ...

  9. Linux服务器宕机案例一则

    案例环境 操作系统 :Oracle Linux Server release 5.7 64bit 虚拟机 硬件配置 : 物理机型号为DELL R720 资源配置 :RAM 8G Intel(R) Xe ...

  10. 【ASM】ASMSNMP用户已存在

    [ASM]ASMSNMP用户已存在 During Oracle Grid Infrastructure for a cluster installation, the ASMSNMP account ...