1.一个有@Transactional的方法被没有@Transactional方法调用时,会导致Transactional作用失效。也是最容易出现的情况。
那为啥会出现这种情况?其实这还是由于使用Spring AOP
代理造成的,因为只有当事务方法被当前类以外的代码调用时,才会由Spring
生成的代理对象来管理。
2.对非public方法进行事务注解。@Transactional 将会失效。
原因:是应为在Spring AOP代理时,事务拦截器在目标方法前后进行拦截,DynamicAdvisedInterceptor
的intercept 方法会获取Transactional注解的事务配置信息,
因为在Spring AOP 代理时,如上图所示
TransactionInterceptor
(事务拦截器)在目标方法执行前后进行拦截, DynamicAdvisedInterceptor
(CglibAopProxy 的内部类)的 intercept 方法或 JdkDynamicAopProxy
的 invoke 方法会间接调用 AbstractFallbackTransactionAttributeSource
的 computeTransactionAttribute
方法会间接调用 AbstractFallbackTransactionAttributeSource
的 computeTransactionAttribute
方法,这个方法会获取Transactional 注解的事务配置信息。他会首先校验事务方法的修饰符是不是public,不是 public则不会获取@Transactional 的属性配置信息。 3.Transactional 事务配置属性中的propagation 属性配置的问题。
当propagation属性配置为:
TransactionDefinition.PROPAGATION_SUPPORTS
:如果当前存在事务,则加入该事务;如果当前没有事务,则以非事务的方式继续运行。 TransactionDefinition.PROPAGATION_NOT_SUPPORTED
:以非事务方式运行,如果当前存在事务,则把当前事务挂起。 TransactionDefinition.PROPAGATION_NEVER
:以非事务方式运行,如果当前存在事务,则抛出异常 4.还存在一种情况:
在一个类中A方法被事务注释,B方法也被事务注释。
@ Transactional
public void A(){
try{
this.B();
}catch(Exception e){
logger.error();
}
}
但在执行B方法是报错,但是异常被A catch 住,此时事务也会失效。