springboot事务的失效场景

 

目录

1、数据库引擎不支持事务

2、没有被 Spring 管理

3、没有配置事务管理器

4、方法不是 public 的

5、事务设置了“NOT_SUPPORTED”,不支持事务

6、发生自身调用时

 7、异常


1、数据库引擎不支持事务

        mysql数据库的MyISAM 引擎是不支持事务操作的,一般要支持事务都会使用 InnoDB 引擎。(从 MySQL 5.5.5 开始的默认存储引擎是:InnoDB)。

2、没有被 Spring 管理

         如果类没有使用@Servcie注解,则该类就没有被spring管理,则事务( @Transactional)自然就失效了。

3、没有配置事务管理器

        springboot只要引入了 spring-boot-starter-data-jdbc 启动器依赖就会自动配置 DataSourceTransactionManager 数据源事务管理器。

传统的 Spring 框架需要配置的代码:

@Bean
public PlatformTransactionManager transactionManager(DataSource dataSource) {
    return new DataSourceTransactionManager(dataSource);
}

4、方法不是 public 的

@Transactional 注解只能用于 public 的方法上,否则事务不会失效。

5、事务设置了“NOT_SUPPORTED”,不支持事务

  @Transactional(propagation = Propagation.NOT_SUPPORTED)
    public void updateOrder(Order order) {
        // update order
    }

6、发生自身调用时

调类自己的方法,而没有经过 Spring 的代理类,默认只有调用外部代理类的方法事务才会生效。

不优雅的解决方法:在类中注入自己这个类,用注入的对象再调用另外一个方法,在 Spring 中可以在当前线程中暴露并获取当前代理类,通过在启动类上添加以下注解启用暴露代理类

1.启动类上添加
@EnableAspectJAutoProxy(exposeProxy = true)
2.调用方法:Spring 默认只有调用 Spring 代理类的 public 方法事务才能生效。
((自己那个类) AopContext.currentProxy()).调用的方法();

 7、异常

该方法只对异常进行捕获,没有抛出

你可能感兴趣的:(spring,boot,后端,java)