这段时间遇到一个问题,程序里明明插入了一条记录,但在后边的一段Procedure中却查不到刚刚插入的记录,最后发现这个Procedure的定义中加入了PRAGMA AUTONOMOUS_TRANSACTION。

PRAGMA AUTONOMOUS_TRANSACTION中文翻译过来叫“自治事务”(翻译的还算好理解),对于定义成自治事务的Procedure,实际上相当于一段独立运行的程序段,这段程序不依赖于主程序,也不干涉主程序

自治事务的特点

第一,这段程序不依赖于原有Main程序,比如Main程序中有未提交的数据,那么在自治事务中是查找不到的。

第二,在自治事务中,commit或者rollback只会提交或回滚当前自治事务中的DML,不会影响到Main程序中的DML。

Autonomous Transaction Demo 1

Without Pragma Autonomous Transaction

  1.  
    CREATE TABLE t (
  2.  
    test_value VARCHAR2(25));
  3.  
     
  4.  
    CREATE OR REPLACE PROCEDURE child_block IS
  5.  
     
  6.  
    BEGIN
  7.  
    INSERT INTO t
  8.  
    (test_value)
  9.  
    VALUES
  10.  
    ('Child block insert');
  11.  
    COMMIT;
  12.  
    END child_block;
  13.  
    /
  14.  
     
  15.  
    CREATE OR REPLACE PROCEDURE parent_block IS
  16.  
     
  17.  
    BEGIN
  18.  
    INSERT INTO t
  19.  
    (test_value)
  20.  
    VALUES
  21.  
    ('Parent block insert');
  22.  
     
  23.  
    child_block;
  24.  
     
  25.  
    ROLLBACK;
  26.  
    END parent_block;
  27.  
    /
  28.  
     
  29.  
    -- run the parent procedure
  30.  
    exec parent_block
  31.  
     
  32.  
    -- check the results
  33.  
    SELECT * FROM t;
  1.  
    Output:
  2.  
    Parent block insert
  3.  
    Child block insert

With Pragma Autonomous Transaction

  1.  
    CREATE OR REPLACE PROCEDURE child_block IS
  2.  
     
  3.  
    PRAGMA AUTONOMOUS_TRANSACTION;
  4.  
     
  5.  
    BEGIN
  6.  
    INSERT INTO t
  7.  
    (test_value)
  8.  
    VALUES
  9.  
    ('Child block insert');
  10.  
     
  11.  
    COMMIT;
  12.  
    END child_block;
  13.  
    /
  14.  
     
  15.  
    CREATE OR REPLACE PROCEDURE parent_block IS
  16.  
     
  17.  
    BEGIN
  18.  
    INSERT INTO t
  19.  
    (test_value)
  20.  
    VALUES
  21.  
    ('Parent block insert');
  22.  
     
  23.  
    child_block;
  24.  
     
  25.  
    ROLLBACK;
  26.  
    END parent_block;
  27.  
    /
  28.  
    -- empty the test table
  29.  
    TRUNCATE TABLE t;
  30.  
     
  31.  
    -- run the parent procedure
  32.  
    exec parent_block;
  33.  
     
  34.  
    -- check the results
  35.  
    SELECT * FROM t;
  1.  
    Output:
  2.  
    Child block insert

Autonomous Transaction Demo 2

Without Pragma Autonomous Transaction

  1.  
    DROP TABLE t;
  2.  
     
  3.  
    CREATE TABLE t (testcol NUMBER);
  4.  
     
  5.  
    CREATE OR REPLACE FUNCTION howmanyrows RETURN INTEGER IS
  6.  
    i INTEGER;
  7.  
    BEGIN
  8.  
    SELECT COUNT(*)
  9.  
    INTO i
  10.  
    FROM t;
  11.  
     
  12.  
    RETURN i;
  13.  
    END howmanyrows;
  14.  
    /
  15.  
     
  16.  
    CREATE OR REPLACE PROCEDURE testproc IS
  17.  
    a INTEGER;
  18.  
    b INTEGER;
  19.  
    c INTEGER;
  20.  
    BEGIN
  21.  
    SELECT COUNT(*)
  22.  
    INTO a
  23.  
    FROM t;
  24.  
     
  25.  
    INSERT INTO t VALUES (1);
  26.  
    COMMIT;
  27.  
     
  28.  
    INSERT INTO t VALUES (2);
  29.  
    INSERT INTO t VALUES (3);
  30.  
     
  31.  
    b := howmanyrows;
  32.  
     
  33.  
    INSERT INTO t VALUES (4);
  34.  
    INSERT INTO t VALUES (5);
  35.  
    INSERT INTO t VALUES (6);
  36.  
    COMMIT;
  37.  
     
  38.  
    SELECT COUNT(*)
  39.  
    INTO c
  40.  
    FROM t;
  41.  
     
  42.  
    dbms_output.put_line(a);
  43.  
    dbms_output.put_line(b);
  44.  
    dbms_output.put_line(c);
  45.  
    END testproc;
  46.  
    /
  47.  
     
  48.  
    set serveroutput on
  49.  
     
  50.  
    exec testproc
  1.  
    Output:
  2.  
    0
  3.  
    3
  4.  
    6
  5.  
    Total execution time 2.782 sec.

With Pragma Autonomous Transaction

  1.  
    CREATE OR REPLACE FUNCTION howmanyrows RETURN INTEGER IS
  2.  
    i INTEGER;
  3.  
     
  4.  
    PRAGMA AUTONOMOUS_TRANSACTION;
  5.  
    BEGIN
  6.  
    SELECT COUNT(*)
  7.  
    INTO i
  8.  
    FROM t;
  9.  
     
  10.  
    RETURN i;
  11.  
    END howmanyrows;
  12.  
    /
  13.  
     
  14.  
    -- empty the test table
  15.  
    TRUNCATE TABLE t;
  16.  
     
  17.  
    exec testproc;
  1.  
    Output:
  2.  
    0
  3.  
    1
  4.  
    6

转载请注明出处:http://blog.csdn.net/pan_tian/article/details/7675800

oracle自治事务(PRAGMA AUTONOMOUS_TRANSACTION)的更多相关文章

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

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

  2. Oracle - 自治事务autonomous transaction

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

  3. Oracle自治事务

    定        义: Autonomous transactions are independent transactions that can be called from within anot ...

  4. Oracle自治事务实际用例

    如下,新建两个存储过程: 在主自治事务中,我们插入一条记录,然后在自治事务中,查看表中行数,然后尝试插入三条记录,查看行数,最后rollback 查看行数,最后返回主事务,查看行数. 1.如下代码: ...

  5. oracle函数自治事务解决不能增改删的语句操作

    CREATE OR REPLACE FUNCTION SEQ3 (v_bname in VARCHAR2) return NUMBER is pragma autonomous_transaction ...

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

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

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

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

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

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

  9. oracle:触发器,自治事务 trigger

    create or replace trigger TRI_FC83_INSERT before insert ON FC83 FOR EACH ROW declare PRAGMA AUTONOMO ...

随机推荐

  1. java高级进阶

  2. xterm配置

    最近转到i3wm桌面下, 发现调用xfce4-terminal有些慢,索性卸载掉一切所谓高级的终端,使用xterm,其实这个才是更牛的家伙. 安装 apt install xterm in i3-wm ...

  3. android textiew自定义ClickableSpan无效问题

    我们有个需求,需要将一段文本中的url跳转,替换成跳转我们app的某个页面.然后就开始搞,先自定义clickspan,在设置LinkMovementMethoid, 但是不管怎么搞就是不生效. 这是我 ...

  4. 在Vuex使用 以及 dispatch和commit来调用mutations的区别

    main.js中 import Vuex from 'vuex' Vue.use(vuex); const store = new Vuex.store({ state: { nickName: &q ...

  5. 《Java核心技术(卷一)》读书笔记——第六章:内部类

    1.      内部类的概念? 类中类 2.      为什么要用内部类? 内部类的方法可以访问外部类的实例域 内部类对外部类的同一个包中的类实现了隐藏 匿名内部类在“想要定义一个回调函数却又不想编写 ...

  6. linux 下 mysql 常用命令

    linux 下 mysql 常用命令   阅读目录 ====================== 1.开启和关闭 1.1.开启 1.2.关闭 1.3.重启 2.登录 2.1.密码明文 2.2.密码密文 ...

  7. AOP统一处理Web请求日志

    <!--aop--> <dependency> <groupId>org.springframework.boot</groupId> <arti ...

  8. 20164301 Exp3 免杀原理与实践

    Exp3 免杀原理与实践  1. 实践内容 1.1 正确使用msf编码器,msfvenom生成如jar之类的其他文件,veil-evasion,加壳工具,使用shellcode编程 1.2 通过组合应 ...

  9. Spark开发环境搭建(IDEA、Scala、SVN、SBT)

    软件版本 软件信息 软件名称 版本 下载地址 备注 Java 1.8 https://www.oracle.com/technetwork/java/javase/downloads/jdk8-dow ...

  10. [双系统linux] ----双系统切换导致系统时间错误

    安装了linux双系统以后,发现每次双系统切换以后系统时间总会错误. 原因:Linux和win7(win10)双系统时间错误问题 时间相差8小时 MAC/linux 将系统硬件时间看待为UTC, 即U ...