spring 事务传播行为实例分析

https://blog.csdn.net/pml18710973036/article/details/58607148

spring 事务传播行为实例分析

2017年02月28日 17:29:38 阿里-橙鹰-潘民兰 阅读数:16096 标签: spring事务 更多

个人分类: springmybatis

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/pml18710973036/article/details/58607148

Spring事务传播行为:

spring特有的事务传播行为,spring支持7种事务传播行为,确定客户端和被调用端的事务边界(说得通俗一点就是多个具有事务控制的service的相互调用时所形成的复杂的事务边界控制)下图所示为7钟事务传播机制

o   

传播行为

含义

PROPAGATION_REQUIRED(XML文件中为REQUIRED)

表示当前方法必须在一个具有事务的上下文中运行,如有客户端有事务在进行,那么被调用端将在该事务中运行,否则的话重新开启一个事务。(如果被调用端发生异常,那么调用端和被调用端事务都将回滚)

PROPAGATION_SUPPORTS(XML文件中为SUPPORTS)

表示当前方法不必需要具有一个事务上下文,但是如果有一个事务的话,它也可以在这个事务中运行

PROPAGATION_MANDATORY(XML文件中为MANDATORY)

表示当前方法必须在一个事务中运行,如果没有事务,将抛出异常

PROPAGATION_NESTED(XML文件中为NESTED)

表示如果当前方法正有一个事务在运行中,则该方法应该运行在一个嵌套事务中,被嵌套的事务可以独立于被封装的事务中进行提交或者回滚。如果封装事务存在,并且外层事务抛出异常回滚,那么内层事务必须回滚,反之,内层事务并不影响外层事务。如果封装事务不存在,则同PROPAGATION_REQUIRED的一样

PROPAGATION_NEVER(XML文件中为NEVER)

表示当方法务不应该在一个事务中运行,如果存在一个事务,则抛出异常

PROPAGATION_REQUIRES_NEW(XML文件中为REQUIRES_NEW)

表示当前方法必须运行在它自己的事务中。一个新的事务将启动,而且如果有一个现有的事务在运行的话,则这个方法将在运行期被挂起,直到新的事务提交或者回滚才恢复执行。

PROPAGATION_NOT_SUPPORTED(XML文件中为NOT_SUPPORTED)

表示该方法不应该在一个事务中运行。如果有一个事务正在运行,他将在运行期被挂起,直到这个事务提交或者回滚才恢复执行

 

例子讲解以上七中事务传播机制

假设有类A的方法methodB(),有类B的方法methodB().

1)     PROPAGATION_REQUIRED

如果B的方法methodB()的事务传播特性是propagation_required,那么如下图

 

A.methodA()调用B的methodB()方法,那么如果A的方法包含事务,则B的方法则不从新开启事务,

1、  如果B的methodB()抛出异常,A的methodB()没有捕获,则A和B的事务都会回滚;

2、   如果B的methodB()运行期间异常会导致B的methodB()的回滚,A如果捕获了异常,并正常提交事务,则会发生Transaction rolled back because it has been marked as rollback-only的异常。

3、  如果A的methodA()运行期间异常,则A和B的Method的事务都会被回滚

 

 

2)     PROPAGATION_SUPPORTS

如果B的方法methodB()的事务传播特性是propagation_supports,么如下图

 

A.methodA()调用B的methodB()方法,那么如果A的方法包含事务,则B运行在此事务环境中,如果A的方法不包含事务,则B运行在非事务环境;

1、如果A没有事务,则A和B的运行出现异常都不会回滚。

2、如果A有事务,A的method方法执行抛出异常,B.methodB和A.methodA都会回滚。

3、如果A有事务,B.method抛出异常,B.methodB和A.methodA都会回滚,如果A捕获了B.method抛出的异常,则会出现异常Transactionrolled back because it has been marked as rollback-only。

 

3)     PROPAGATION_MANDATORY

表示当前方法必须在一个事务中运行,如果没有事务,将抛出异常,如下图调用关系:

 

B.methodB()事务传播特性定义为:PROPAGATION_MANDATORY

 

1、如果A的methoda()方法没有事务运行环境,则B的methodB()执行的时候会报如下异常:No existingtransaction found for transaction marked with propagation 'mandatory'

2、如果A的Methoda()方法有事务并且执行过程中抛出异常,则A.methoda()和B.methodb()执行的操作被回滚;

3、如果A的methoda()方法有事务,则B.methodB()抛出异常时,A的methoda()和B.methodB()都会被回滚;如果A捕获了B.method抛出的异常,则会出现异常Transaction rolled back because ithas been marked as rollback-only

 

 

4)     PROPAGATION_NESTED

如有一下方法调用关系,如图:

B的methodB()定义的事务为PROPAGATION_NESTED;

 

1、        如果A的MethodA()不存在事务,则B的methodB()运行在一个新的事务中,B.method()抛出的异常,B.methodB()回滚,但A.methodA()不回滚;如果A.methoda()抛出异常,则A.methodA()和B.methodB()操作不回。

2、        如果A的methodA()存在事务,则A的methoda()抛出异常,则A的methoda()和B的Methodb()都会被回滚;

3、        如果A的MethodA()存在事务,则B的methodB()抛出异常,B.methodB()回滚,如果A不捕获异常,则A.methodA()和B.methodB()都会回滚,如果A捕获异常,则B.methodB()回滚,A不回滚;

5)PROPAGATION_NEVER

表示事务传播特性定义为PROPAGATION_NEVER的方法不应该运行在一个事务环境中

有如下调用关系:

 

如果B.methodB()的事务传播特性被定义为PROPAGATION_NEVER,则如果A.methodA()方法存在事务,则会出现异常Existingtransaction found for transaction marked with propagation 'never'。

6)PROPAGATION_REQUIRES_NEW

      表示事务传播特性定义为PROPAGATION_REQUIRES_NEW的方法需要运行在一个新的事务中。

如有一下调用关系:B.methodB()事务传播特性为PROPAGATION_REQUIRES_NEW.

 

1、        如果A存在事务,A.methodA()抛出异常,A.methodA()的事务被回滚,但B.methodB()事务不受影响;如果B.methodB()抛出异常,A不捕获的话,A.methodA()和B.methodB()的事务都会被回滚。如果A捕获的话,A.methodA()的事务不受影响但B.methodB()的事务回滚。

7) PROPAGATION_NOT_SUPPORTED

表示该方法不应该在一个事务中运行。如果有一个事务正在运行,他将在运行期被挂起,直到这个事务提交或者回滚才恢复执行。

如有一下调用关系图:

 

如果B.methodB()方法传播特性被定义为:PROPAGATION_NOT_SUPPORTED。

1、        如果A.methodA()存在事务,如果B.methodB()抛出异常,A.methodA()不捕获的话,A.methodA()的事务被回滚,而B.methodB()出现异常前数据库操作不受影响。如果A.methodA()捕获的话,则A.methodA()的事务不受影响,B.methodB()异常抛出前的数据操作不受影响。

 

 

实际场景中的七大事务传播行为的使用

1、  在一个话费充值业务处理逻辑中,有如下图所示操作:

 

 

业务需要扣款操作和创建订单操作同成功或者失败,因此,charger()和order()的事务不能相互独立,需要包含在chargeHandle()的事务中;

通过以上需求,可以给charge()和order()的事务传播行为定义成:PROPAGATION_MANDATORY

只要charge()或者order()抛出异常整个chargeHandle()都一起回滚,即使chargeHandle()捕获异常也没用,不允许提交事务。

2、  如果业务需求没接受到一次请求到要记录日志到数据库,如下图:

 

 

因为log()的操作不管扣款和创建订单成功与否都要生成日志,并且日志的操作成功与否不影响充值处理,所以log()方法的事务传播行为可以定义为:PROPAGATION_REQUIRES_NEW.

3、  在订单的售后处理中,更新完订单金额后,需要自动统计销售报表,如下图所示:

 

 

根据业务可知,售后是已经处理完订单的充值请求后的功能,是对订单的后续管理,统计报表report()方法耗时较长,因此,我们需要设置report()的事务传播行为为:PROPAGATION_NEVER,表示不适合在有事务的操作中调用,因为report()太耗时。

4、  在银行新增银行卡业务中,需要执行两个操作,一个是保存银行卡信息,一个是登记新创建的银行卡信息,其中登记银行卡信息成功与否不影响银行卡的创建。

 

由以上需求,我们可知对于regster()方法的事务传播行为,可以设置为PROPAGATION_NESTED,action()事务的回滚,regster()保存的信息就没意义,也就需要跟着回滚,而regster()的回滚不影响action()事务;insert()的事务传播行为可以设置为PROPAGATION_REQUIRED, PROPAGATION_MANDATORY,即insert()回滚事务,action()的事务必须跟着回滚。

想对作者说点什么? 我来说一句

事务传播性是什么?

 1807

我们都知道事务的概念,那么事务的传播特性是什么呢?(此处着重介绍传播特性的概念,关于传播特性的相关配置就不介绍了,可以查看spring的官方文档)         在我们用SSH开发项目的时...来自: 豪猪的博客

Spring的7种事务传播行为类型

 1.8万

1、PROPAGATION_REQUIRED :如果当前没有事务,就创建一个新事务,如果当前存在事务,就加入该事务,该设置是最常用的设置。 2、PROPAGATION_SUPPORTS:支持当前事务,...来自: hsgao_water的博客

spring事务(Transaction)的七种事务传播行为及五种隔离级别

 7007

spring事务(Transaction)的七种事务传播行为及五种隔离级别来自: Java仗剑走天涯

浅析Spring 事务(二十一) spring事务的传播行为

 5219

经过我们上面一个章节的初步了解,我们已经知道了Spring事务的基本配置,今天我们一起接着讨论一下spring事务的传播...来自: BazingaLyncc

事务457——事务的七个传播行为

 519

事务的传播行为。来自: 童小绿 学无止境

Spring:7种事务传播行为

 209

7种事务传播行为所谓事务传播行为就是多个事务方法相互调用时,事务如何在这些方法间传播。Spring支持以下7种事务传播行为。 传播行为含义PROPAGATION_REQUIRED(XML文件中为REQ...来自: 琦彦

Spring 的事务传播行为

 404

虽然网上关于Spring的事务传播行为的博客已经很多了,但是符合通俗易懂的却不多。我写这篇博客就是试图通俗地描述Spring事务的传播行为是什么,Spring事务的传播行为有哪些类型以及它们之间有什么...来自: 亚里斯的专栏

事务的传播行为(讲得比较好)

 1.3万

文章一: 我们都知道事务的概念,那么事务的传播特性是什么呢?(此处着重介绍传播特性的概念,关于传播特性的相关配置就不介绍了,可以查看spring的官方文档)  在我们用SSH开发项目的时候,我们一...来自: IT小小鸟~~

7种事务的传播机制

 2661

事务的传播机制定义在TransactionDefinition接口中,我们也可以通过枚举类Propagation类调用,下面我也附上两个类的源码供参考。 REQUIRED(默认):支持使用当前事务...来自: 青鱼入云的博客

spring的4种事务特性、4种隔离级别、7种传播行为

 1011

1.事务概念事务是程序中一系列严密的操作,所有操作执行必须成功完成,否则在每个操作所做的更改将会被撤销,这也是事务的原子性(要么成功,要么失败)。2.事务特性(4种)事务特性分为四个:原子性(Atom...来自: 李泽昊

相关热词

和spring spring与 下spring spring的 spring和

博主推荐

 换一批

花2不谢

花2不谢

关注 158篇文章

IT丶小污

IT丶小污

关注 60篇文章

isscollege

isscollege

关注 107篇文章

python 判断为空nan, null

 4.3万

pandas 空值定义为numpy.nan对整体的series或Dataframe判断是否未空,用isnull() eg: pd.isnull(df1) #df1是dataframe变量对单独的...

Python中的NULL和None

 1.6万

与C不同的是,在python中是没有NULL的,取而代之的是None,它的含义是为空,但要注意和空列表与空字符串是不一样的,None的类型是Nonetype   >>...来自: 不知道起什么名字

python实现java的hashcode方法

 362

def convert_n_bytes(n, b): bits = b * 8 return (n + 2 ** (bits - 1)) % 2 ** bits - 2 ** (bits ...来自: sqlaowen的博客

事务的传播行为

 17

举例: 用户想要买两本书,但是账户的钱只够支付一本书,这时需要先支付一本。 如果事默认的事务传播行为(REQUIRED),则两本书都不能购买成功,这是需要将事务的传播行为设置为REQUIRES_N...来自: qq_36722039的博客

Spring事务原理及事务传播行为

 36

事务的四大基本特性: 事物的概述 ⑴ 原子性(Atomicity)   原子性是指事务包含的所有操作要么全部成功,要么全部失败回滚,因此事务的操作如果成功就必须要完全应用到数据库,如果操作失败...来自: itcats_cn的博客

spring事物管理全面概括

 1672

讲述事物的特性、事务的实现方式、事物的原理、声明式事务管理五种实现方式 3.隔离性:一个事物的执行,不受其他事务的干扰,即并发执行的事物之间互不干扰 4.持久性:一个事物一旦提交,它对数据库的改...来自: hotpots--火锅技术栈

浅析Spring事务传播行为和隔离级别

 1.7万

7个传播行为,4个隔离级别。 Spring事务的传播行为和隔离级别[transaction behavior and isolated level] Spring中事务的定义: Propagation...来自: Champion.Wong 的专栏

【Spring】——事务实现过程及原理

 1.9万

1、Spring中事务处理的作用:   Spring事务处理,是将事务处理的工作统一起来,并为事务处理提供通用的支持。   2、工作原理及实现   a、划分处理单元——IOC ...来自: 遇见未来的自己

Spring事务之七(事务自动提交)

 7064

更多文章:http://zhuqiuhui.space/ 一、MySQL数据库事务自动提交     对于mysql数据库,默认情况下,数据库处于自动提交模式。每一条语句处于一个单独的事...来自: 苦行僧

[Java][Spring]Spring事务不起作用 问题汇总

 1.7万

最近在项目的时候碰到pring事务不起作用的情况,后来解决了,这里我汇总下:   1、首先使用如下代码 确认你的bean 是代理对象吗? 必须是Spring定义(通过XML或注解定义...来自: 王德封-逐浪

java三大框架之spring事务传播行为

 2101

•当事务方法被另一个事务方法调用时,必须指定事务应该如何传播.例如:方法可能继续在现有事务中运行,也可能开启一个新事务,并在自己的事务中运行. •事务的传播行为可以由传播属性指定.Spring 定义了...来自: 花2不谢

Hibernate事务传播行为种类

 362

Hibernate事务传播行为种类 (原文地址:http://m.blog.csdn.net/u014656992/article/details/50815341) ...来自: IT丶小污的博客

关于spring事务的7种传播方式

 467

传播行为 事务的第一个方面是传播行为(propagationbehavior)。当事务方法被另一个事务方法调用时,必须指定事务应该如何传播。例如:方法可能继续在现有事务中运行,也可能开启一个新事务,...来自: 软通大学企业博客

Spring事务的传播行为、隔离级别、回滚、只读和过期

 153

事务的传播性- 当事务的方法被另一个事务的方法调用时,必须指定事务应该如何传播。如:方法可能继续在现有的事务中运行,也可能开启一个新的事务,并在自己的事务中运行。- 事务的传播行为可以由传播属性指定。...来自: 一颗洛米

Spring传播行为内部方法不起作用

 1177

在使用Spring的注解事务时候,我们发现内部方法声明的事务不起作用,而是决定于外部方法注解的事务。到底是真不起作用,还是我们我们Spring的事务注解机制理解错了,导致误用了。下面我们看两个例子: ...来自: hsgao_water的博客

Spring事务的7个传播行为,4个隔离级别

 5047

Spring事务的传播行为和隔离级别[transaction behavior and isolated level] Spring中事务的定义:  一、Propagation  k...来自: 辉悦天成的专栏

事务传播行为种类

 12

Spring在TransactionDefinition接口中规定了7种类型的事务传播行为, 它们规定了事务方法和事务方法发生嵌套调用时事务如何进行传播: 事务传播行为类型 事务传播行为类型 ...来自: weixin_42833888的博客

使用Spring注解方式管理事务与传播行为详解

 9498

前面讲解了怎么使用@Transactional注解声明PersonServiceBean底下所有的业务方法需要事务管理,那么事务是如何来管理的呢? 我们知道当每个业务方法执行的时候,它都会打开事务,...来自: 李阿昀的博客

Spring事务的传播行为

 270

Spring的传播行为确定了客户端和被调用端的事务边界,简单来说就是多个具有事务控制的Service的相互调用时所形成的复杂的事务边界控制。Spring定义了7种传播行为,定义的枚举代码如下: ...来自: Martin的博客

揭开互联网公司的神秘面纱,数据解读那些slay整个行业的互联网公司

 3402

...来自: 程序人生的博客

阿里-橙鹰-潘民兰

关注

原创

34

粉丝

31

喜欢

19

评论

21

等级:

 

访问:

 

22万+

积分:

 

1851

排名:

 

3万+

勋章:

最新文章

个人分类

展开

归档

展开

热门文章

最新评论

联系我们

扫码联系客服

扫码联系客服

下载CSDN APP

下载CSDN APP

kefu@csdn.net400-660-0108

QQ客服客服论坛

关于我们招聘广告服务 网站地图

百度提供站内搜索 京ICP证09002463号

©2018 CSDN版权所有

经营性网站备案信息网络110报警服务

北京互联网违法和不良信息举报中心

中国互联网举报中心

开发者调查

AI开发者大会日程曝光

告别知识焦虑,即刻启程

 

登录

注册

 

  • 14

  • 12

  •  
  •  
  •  
  •  
  •  

 

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值