Oracle的自治事务

关于自治事务和分布式事务的定义,请大家参考Oracle本身的参考资料.

下面是个简单的测试转载,可以让大家更加清楚的明白自治事务和非自治事务的区别.

SQL> create table chris_test (name varchar2(200));

Table created.

SQL> create or replace procedure Autonomous_insert
  2  as
  3     pragma autonomous_transaction;
  4  begin
  5     insert into chris_test values ('Autonomous Insert!');
  6     commit;
  7  end;
  8  /

Procedure created.

SQL> create or replace procedure Nonnomous_insert
  2  as
  3  begin
  4     insert into chris_test values ('Nonnomous Insert!');
  5     commit;
  6  end;
  7  /

Procedure created.

SQL> begin
  2     insert into chris_test values ('Anonymous Block!');
  3     Nonnomous_insert;
  4     rollback;
  5  end;
  6  /

PL/SQL procedure successfully completed.

SQL> select * from chris_test;

NAME
--------------------------------------------------------------------------------
Anonymous Block!
Nonnomous Insert!

SQL> truncate table chris_test;

Table truncated.

SQL> begin
  2     insert into chris_test values ('Anonymous Block!');
  3     Autonomous_insert;
  4     rollback;
  5  end;
  6  /

PL/SQL procedure successfully completed.

SQL> select * from chris_test;

NAME
--------------------------------------------------------------------------------
Autonomous Insert!
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值