SpringBoot事务不生效可能存在的原因

1.mysql表必须支持事务:引擎为INNODB2.SpringBoot启动事务@EnableTransactionManagement3.方法上加注解@Transactional//默认只对RuntimeException起作用,可修改4.方法必须为public修饰5.同类中事务的方法不能嵌套在其他方法中, QQQ类中A方法调用B方法,B方法开启事务注解,B方法中事务不会生效。 将A方法放到其他类中,B方法为QQQ类中的一级方法并加注解,事务就会生效。==============.
摘要由CSDN通过智能技术生成

1.mysql表必须支持事务:引擎为INNODB

2.SpringBoot启动事务@EnableTransactionManagement

3.方法上加注解@Transactional//默认只对RuntimeException起作用,可修改

4.方法必须为public修饰

5.同类中事务的方法不能嵌套在其他方法中, QQQ类中A方法调用B方法,B方法开启事务注解,B方法中事务不会生效。 将A方法放到其他类中,B方法为QQQ类中的一级方法并加注解,事务就会生效。

 

=======================================================================================================================================================

 

一. 配置

将使用声明式事务,首先我们创建一个 SpringBoot 项目,版本为2.3.1.RELEASE,使用 mysql 作为目标数据库,存储引擎选择Innodb,事务隔离级别为 RR,springboot主方法入口开启@EnableTransactionManagement

 

二. 不生效

比如声明式事务注解@Transactional主要是结合代理实现,结合 AOP 的知识点,至少可以得出放在私有方法上,类内部调用都不会生效,下面进入详细说明

1. 数据库

事务生效的前提是你的数据源得支持事务,比如 mysql 的 MyISAM 引擎就不支持事务,而 Innodb 支持事务

下面的 case 都是基于 mysql + Innodb 引擎

为后续的演示 case,我们准备一些数据如下

@Servicepublic class NotEffectDemo {

    @Autowired

    private JdbcTemplate jdbcTemplate;

    @PostConstruct

    public void init() {

        String sql = "replace into money (id, name, money) values" + " (520, '初始化', 200)," + "(530, '初始化', 200)," +

                "(540, '初始化', 200)," + "(550, '初始化', 200)";

        jdbcTemplate.execute(sql);

    }

}复制代码

2. 类内部访问

简单来讲就是指非直接访问带注解标记的方法 B,而是通过类普通方法 A,然后由 A 访问 B

下面是一个简单的 case

/**

 * 非直接调用,不生效

 *

 * @param id

 * @return

 * @throws Exception

 */@Transactional(rollbackFor = Exception.class)public boolean testCompileException2(int id) throws Exception {

    if (this.updateName(id)) {

        this.query("after update name", id);

        if (this.update(id)) {

            return true;

        }

    }

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值