Spring事务小记

1. 事务的传播属性

  1. REQUIRED:默认属性,如果当前已有事务,则加入并且忽略自身的设置,否则自己创建一个新的事务

  2. MANDATORY:支持当前事务,若当前没有事务则抛出异常

  3. NEVER:以非事务方式运行,如果当前存在事务,则抛出异常

  4. NOT_SUPPORTED:以非事务方式运行,如果当前存在事务,把当前事务挂起

  5. REQUIRES_NEW:使用独立的事务,不参与外部的事务,独立的回滚和提交

  6. SUPPORTS :支持当前事务,当前有事务则加入,否则以非事务方式运行

  7. NESTED:与当前事务同步回滚或提交,外层可以影响内层的回滚,内层的失败不会引起外层的回滚

  示例请参考:https://zhuanlan.zhihu.com/p/148504094

2. Spring事务隔离级别

  1. DEFAULT :跟数据库的隔离界别保持一致

  2. READ_UNCOMMITTED:读未提交

  3. READ_COMMITTED:读已提交

  4. REPEATABLE_READ:可重复读

  5. SERIALIZABLE:串行化

3. 事务失效的场景

  1. 注解加到非public方法。在AOP的源码,对类中的方法匹配适用增强时,只能获取这个类的公有方法, Method[] methods = clazz.getMethods(); 。

  2. 类中一个方法调用另一个方法,这时不会走代理

    解决方案:只要思想还是向拿到代理

    1. 类中注入自己

    2. getBean。实现ApplicationContextAware接口,使用ApplicationContext获取Bean。参考:https://www.jianshu.com/p/4c0723615a52

@Component
public class BeanUtil implements ApplicationContextAware {
    private static ApplicationContext applicationContext;
    @Override
    public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
        BeanUtil.applicationContext = applicationContext;
    }

    public static Object getBean(String beanName) {
        return applicationContext.getBean(beanName);
    }
}

    3. 配置 @EnableAspectJAutoProxy(exposeProxy = true) 让代理暴露,然后获取当前类的代理对象 AopContext.currentProxy() 。参考:https://blog.csdn.net/JustForSS/article/details/83008824

  3. 异常被捕获了

  4. 不是指定回滚的异常,默认只回滚非受检异常(RuntimeException和Error)

  5. 事务的传播行为配置不对。一个事务调用另一个事务,按照业务需求配置传播行为

 

 

 

参考:

1. https://www.cnblogs.com/eunice-sun/p/11024584.html

2. https://blog.csdn.net/zzti_erlie/article/details/115578562

posted @ 2021-04-18 18:24  walker993  阅读(34)  评论(0)    收藏  举报