mysql 事务不生效_@Transactional事务不生效的几种解决方案

本文详细分析了Spring中@Transactional注解事务失效的七种情况,包括:数据库不支持事务(如MyISAM引擎)、方法访问权限不足、异常处理不当、方法内部直接调用、多数据源事务配置问题、新开启线程以及事务传播属性设置错误,并提供了相应的解决办法。
摘要由CSDN通过智能技术生成

Spring事务管理方式

编码式事务管理:将事务控制代码编写在业务代码之中。

声明式事务管理:基于AOP(面向切面编程),事务管理与业务逻辑解耦。

声明式事务管理的两种实现:(1)在配置文件(xml)中配置。(2)基于@Transactional注解。

@Transactional使用起来方便,但也需要注意引起@Transactional失效的场景,本文总结了七种情况,下面进行逐一分析:

一、数据库本身不支持

MySql 的 MyISAM 引擎不支持回滚,如果需要自动回滚事务,需要将MySql的引擎设置成InnoDB;

二、注解的方法是否为public

//@Transactional注解在private方法上会失效

@Transactional

private void deleteUser() throws MyException{

userMapper.deleteUserA();

int i = 1/0;

userMapper.deleteUserB();

}

idea直接会给出提示Methods annotated with ‘@Transactional’ must be overridable ,原理很简单,private修饰的方式,spring无法生成动态代理,AOP代理分别在intercept()和invoke()方法判断是否进行事务拦截,这两个方法都会间接调用AbstractFallbackTransactionAttributeSource类的computeTransactionAttribute方法来获取事务控制的相关属性。这其中有以下一段代码<

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值