PROPAGATION_REQUIRES_NEW 和 PROPAGATION_NESTED區別

PROPAGATION_REQUIRES_NEW 和 PROPAGATION_NESTED两种传播机制的是容易混淆的。
   
   1. 开启事务的多少,PROPAGATION_REQUIRES_NEW会开启很多事务,外部事务挂起,里面的事务独立执行,对性能的损耗较大。PROPAGATION_NESTED为父子事务,实际上是借助jdbc的savepoint实现的,属于同一个事物。
2. PROPAGATION_NESTED的回滚可以总结为,子事务回滚到savepoint,父事务可选择性回滚或者不不滚;父事务回滚子事务一定回滚。

PROPAGATION_NESTED如一下一樣

在oracle數據庫中

CREATE OR REPLACE PROCEDURE pro_test(fbuildareac IN VARCHAR2)
AS
BEGIN
update t_broker_house set fhousecondition=fid  where fid='ed7c17ec-ca2a-4fe7-b7f7-f8111c102ade';
savepoint a;
update t_broker_house set fhousecondition=fid  where fid='f456255f-1934-424f-81fb-6654829d4651';
rollback to a;
update t_broker_house set fhousecondition=fid  where fid='bac6e97b-05f4-47db-b849-75d7d72d5ba6';
commit;
    DBMS_OUTPUT.put_line (fbuildareac);
END pro_test;

begin
  pro_test('123');
 end;

第1個和第3個是可以修改成功的 第二個事务回滚

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值