Oracle 嵌套事务与自治事务

本文详细介绍了Oracle数据库中的嵌套事务(Nested Transaction)和自治事务(Autonomous Transaction),通过实例展示了它们的区别和使用场景。嵌套事务在主事务中运行,其提交与主事务密切相关;自治事务在函数或过程内部独立管理,不受外部事务影响,常用于日志记录。文章通过创建表格和执行PL/SQL代码,展示了如何操作这两种事务并分析了它们在不同情况下的数据状态。
摘要由CSDN通过智能技术生成

一. 概念 
1. 嵌套事务(Nested Transaction): 
指在一个Parent事务中嵌套的一个或多个Sub Transaction.并且主事务与其相互影响,这种事务就称为嵌套事务。以Commit作为事务的结束。 
2. 自治事务(Autonomous Transaction): 
指在function,procedure等subprograms中对事务进行自治管理,当在别的pl/sql block里去调用这些subprograms的时候这些subprograms并不随着父pl/sql block的失败而回滚,而是自己管自己commit。以Commit作为事务的结束。自治事务常用于写入LOG或TRAC信息便于查找错误。 
二. 嵌套事务的运用(Nested Transaction) 
1.预备Create Table: 

Sql代码   收藏代码
  1. create table TEST_POLICY  
  2. (  
  3.   POLICY_CODE VARCHAR2(20),  
  4.   POLICY_TYPE CHAR(1)  
  5. )  

2.创建一个嵌套事务的procedure: 
1) 
Sql代码   收藏代码
  1. Procedure P_Insert_Policy(I_Policy_code varchar2(20),   
  2.                             I_Policy_type char(1)) as   
  3.   cnt number :=0;  
  4.   begin  
  5.       select count(1) into cnt from Test_Policy;  
  6.       Dbms_Output.put_line('records of the test_policy is '|| cnt);  
  7.         
  8.       Insert into Test_Policy values(I_Policy_code, I_Policy_type);  
  9.       commit;--commit in nested transaction   
  10.   end P_Insert_Policy;  
  11. --call procedure used in nested transaction  
  12.   PROCEDURE TEST_PL_SQL_ENTRY(  
  13.                               I_POL_ID IN VARCHAR2,  
  14.                               O_SUCC_FLG OUT VARCHAR2) AS  
  15.   strSql varchar2(500);  
  16.   cnt number := 0;  
  17.   BEGIN  
  18.      delete from test_policy;  
  19.      commit;  
  20.      insert into test_policy values('2010042101''1');  
  21.      select count(1) into cnt from Test_Policy;  
  22.      Dbms_Output.put_line('records of the test_policy is '|| cnt);  
  23.      --call nested transaction  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值