Transactional事务失效自检流程

  1. Mysql数据库引擎需为InnnoDB,MyIsam不支持事务
  2. @Transactional所注解的方法是否为public
  3. @Transactional所注解方法所在的类,需被Spring容器所管理,换句话说所注解方法所在的类需要被@Service、@Component所注解
  4. 需要调用该方法,且需要支持事务特性的调用方是在在 @Transactional所在的类的外面。注意:类内部的其他方法调用这个注解了@Transactional的方法,事务是不会起作用的。
  5. 注解为事务范围的方法中,事务的回滚仅仅对于unchecked的异常有效。对于checked异常无效。也就是说事务回滚仅仅发生在出现RuntimeException或Error的时候。如果希望一般的异常也能触发事务回滚,需要在注解了@Transactional的方法上,将@Transactional回滚参数设为:@Transactional(rollbackFor=Exception.class)
  6. try catch 相关语句可能会在事务之前捕捉异常,需要:
1
2
3
4
5
6
7
8
9
10
@Transactional(rollbackFor = Exception.class)
public Integer compute(ProductInfo p){
try{
...
}catch(Exception e){
e.printStackTrace();
TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
return 0;
}
}

Spring 的传播行为

1
2
3
4
5
6
7
8
9
 public enum Propagation {
REQUIRED(0),
SUPPORTS(1),
MANDATORY(2),
REQUIRES_NEW(3),
NOT_SUPPORTED(4),
NEVER(5),
NESTED(6);
}