spring 事务失效的几种场景

以下场景是基于mysql数据库,InnoDB的存储引擎。

下面这种情况,事务不会回滚

@Transactional
public void insertUser(String name){
    try {
        User user = new User();
        user.setName(name);
        userDao.insertUser(user);
        //模拟抛异常
        throw new RuntimeException();
    } catch (RuntimeException e) {
        e.printStackTrace();
    }
}

默认只对runtimeException的类型进行回滚,如果抛出Exception异常是不进行回滚的,如果想回滚要配置@Transactional(rollbackFor = Exception.class)

@Transactional
public void insertUser(String name) throws Exception {

    User user = new User();
    user.setName(name);
    userDao.insertUser(user);
    //模拟抛异常
    throw new Exception();
}

下面这种情况,事务是不生效的,如果要生效,可以把this调用放到另外一个类,insertStu这个放另外一个类,这样可以这个方法有事务

public void insertUser(String name) {
    User user = new User();
    user.setName(name);
    //没有事务,不会回滚,保存成功
    userDao.insertUser(user);
    insertStu(name);
}

@Transactional
public void insertStu(String name){
    Stu stu = new Stu();
    stu.setName(name);
    //没有事务,保存会成功
    stuDao.insertUser(stu);
    throw new RuntimeException();
}

下面这种情况,事务是生效的,注意

@Transactional
public void insertUser(String name) {
    User user = new User();
    user.setName(name);
    //有事务,会回滚,保存不成功
    userDao.insertUser(user);
    insertStu(name);
}

public void insertStu(String name){
    Stu stu = new Stu();
    stu.setName(name);
    //有事务,会回滚,保存不成功
    stuDao.insertUser(stu);
    throw new RuntimeException();
}

如果项目中是多数据源情况,要单独配置事务管理器。当引入jdbc依赖之后,Spring Boot会自动默认分别注入DataSourceTransactionManager或JpaTransactionManager,

所以我们不需要任何额外配置就可以用@Transactional注解进行事务的使用。

Original: https://www.cnblogs.com/jack1990/p/15205556.html
Author: qiushui
Title: spring 事务失效的几种场景

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/565397/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球