在日常工作中发现,随着ibatis类型框架的普及,在日常工作中已经比较少的写事务相关的代码, 以至于小伙伴们经常忽略事务的存在,特别是上来直接使用第三方框架的同学,如果不能很好地理解事务的运行原理, 很容易引起线上的问题。本文罗列Spring事务传播类型,希望有所帮助。
REQUIRED(常用)
REQUIRED事务传播类型表示如果当前没有事务,就创建一个事务,如果已经存在一个事务,就加入这个事务。这是最常见的事务传播类型,也是Spring当中默认的事务传播类型。
REQUIRES_NEW
REQUIRES_NEW事务传播类型表示如果当前存在事务,则把当前事务挂起,并重新创建新的事务并执行,直到新的事务提交或者回滚,才会恢复执行原来的事务。这种事务传播类型具备隔离性,将原有事务和新创建的事务隔离,原有事务和新创建的事务的提交和回滚互不影响。新创建的事务和被挂起的事务没有任何关系,它们是两个不相干的独立事务。外部事务执行失败后回滚,不会回滚内部事务的执行结果。内部事务执行失败抛出异常,被外部事务捕获到时,外部事务可以不处理内部事务的回滚操作。
SUPPORTS
SUPPORTS事务传播类型表示支持当前事务,如果当前没有事务,就以非事务的方式执行。外部不存在事务时,不会开启新的事务,外部存在事务时,将其加入外部事务。
MANDATORY
MANDATORY事务传播类型表示支持当前事务,这种事务传播类型具备强制性,当前操作必须存在事务,如果不存在,则抛出异常。
NOT_SUPPORTED
NOT_SUPPORTED事务传播类型表示以非事务方式执行,如果当前操作在一个事务中,则把当前事务挂起,直到当前操作完成再恢复事务的执行。如果当前操作存在事务,则把事务挂起,以非事务的方式运行。
NEVER
NEVER事务传播类型表示以非事务的方式执行,如果当前操作存在事务,则抛出异常。NEVER事务传播类型和NOT_SUPPORTED事务传播类型的区别是如果当前存在事务,则NEVER事务传播类型会抛出异常,而NOT_SUPPORTED事务传播类型会把当前事务挂起,以非事务的方式执行。NEVER事务传播类型与MANDATORY事务传播类型的区别是NEVER事务传播类型表示如果当前操作存在事务,则抛出异常,而MANDATORY事务传播类型表示如果当前操作不存在事务,则抛出异常。
NESTED
NESTED事务传播类型表示如果当前方法有一个事务正在运行,则这个方法应该运行在一个嵌套事务中,被嵌套的事务可以独立于被封装的事务进行提交或者回滚。如果没有活动事务,则按照REQUIRED事务传播类型执行。如果封装事务存在,并且外层事务抛出异常回滚,那么内层事务必须回滚。如果内层事务回滚,则并不影响外层事务的提交和回滚。如果封装事务不存在,则按照REQUIRED事务传播类型执行。
虽然Spring提供了7种事务传播机制类型,但是在日常工作中经常使用的只有REQU-IRED、NOT_SUPPORTED和REQUIRES_NEW这3种。