Spring事务失效场景

Spring事务失效场景

  1. 数据库不支持事务

    • 比如MySQL数据库的MyISAM存储引擎
  2. 事务方法未被Spring管理

    • 使用Spring注解@Transactional进行事务管理的方法所在的类没有在Spring IOC容器的管理中。
  3. 事务方法不是public修饰符

    • Spring对事务方法时通过AOP实现的,只对public方法进行处理。
  4. 同一个类中没有事务声明的方法调用被声明事务的方法

    • Spring对事务方法时通过AOP实现的,如果最外层方法没有被事务声明时,即时被直接调用的同一个类中的方法上面存在事务,也不会生效。
    • 如果外层的方法上面有事务,直接调用的同一个类中的方法上面即时有事务,也不会直接生效。最终是被外层方法的事务控制。
  5. 未配置事务管理器

    • 如果在项目中没有配置Spring的事务管理器,Spring的事务也不会生效。

      java 复制代码
      @Bean
      public PlatformTransactionManager transactionManager(DataSource dataSource) {
       return new DataSourceTransactionManager(dataSource);
      }
  6. 方法的事务传播类型不支持事务

    • 如果内部方法的事务传播类型为不支持事务的传播类型,内部方法就不会被Spring的事务管理

      java 复制代码
      @Service
      public class OrderService {
       @Autowired
       private OrderDao orderDao;
       @Autowired
       private ProductDao productDao;
      
       @Transactional(propagation = Propagation.REQUIRED)
       public void submitOrder(){
        //生成订单
        Order order = new Order();
        long number = Math.abs(new Random().nextInt(500));
        order.setId(number);
        order.setOrderNo("order_" + number);
        orderDao.saveOrder(order);
        //减库存
        this.updateProductStockCountById(1, 1L);
       }
      
        // 事务传播类型NOT_SUPPORTED,不支持事务
       @Transactional(propagation = Propagation.NOT_SUPPORTED)
       public void updateProductStockCountById(Integer stockCount, Long id){
        productDao.updateProductStockCountById(stockCount, id);
       }
      }
  7. 不正确的捕获异常

    • 如果方法抛出的异常被捕获处理,没有被Spring获取到时,最终会正常提交,不会回滚。
  8. Spring事务管理针对的异常和抛出的异常类型不一致

    • 默认情况下Spring事务注解@Transaction只会针对RuntimeException异常进行处理
    • 如果@Transaction配置的处理异常是RuntimeException,但抛出的异常是Exception,事务失效。
相关推荐
Mike117.1 分钟前
GBase 8c MOT 内存表落地前要先画清楚边界
服务器·数据库
iAm_Ike1 分钟前
c++怎么在写入文件流时通过peek预读功能实现复杂的逻辑判断【实战】
jvm·数据库·python
dFObBIMmai4 分钟前
mysql如何确保主从数据完全同步_开启半同步复制机制
jvm·数据库·python
2501_9307077817 分钟前
使用C#代码压平 PDF 表单字段
数据库·pdf·c#
m0_4708576425 分钟前
CSS如何实现Bootstrap进度条自定义动画_利用keyframe关键帧
jvm·数据库·python
treesforest28 分钟前
IP数据库下载完全指南:免费与商业IP定位库对比
网络·数据库·php
书语时30 分钟前
单体 MySQL 支撑业务的上限一般从哪里先触顶?如何论证瓶颈在 DB?
数据库·mysql
m0_6245785932 分钟前
SQL高效实现基于JOIN的交叉分析_多表关联实现多维统计
jvm·数据库·python
威联通网络存储33 分钟前
QNAP 闪存底座:制造企业 ERP 数据库容灾方案
数据库·python·制造
城数派34 分钟前
1958-2024年乡镇的逐月土壤湿度数据
数据库·arcgis·数据分析·excel