springboot中的事务配置

什么是事务

//在默认情况下,数据库的事物作用范围是在JpaRepository的CRUD方法上,
//save方法一旦执行成功马上提交
//要保证数据的完整性,那就需要将事务提高至imp方法上

怎样开启事务

Spring Boot 使用事务非常简单,首先使用注解 @EnableTransactionManagement 开启事务支持后,然后在访问数据库的Service方法上添加注解 @Transactional 便可。
//在imp方法上开启事务,是需要增加@Transactional
//针对于这种使用注解的事务形式,也有一个名词叫做"声明式事务" , ParseException
示例:

@Transactional(rollbackFor = Exception.class)//开启事务,imp方法运行成功提交。运行失败抛出RuntimeException及其子类的时候回滚
    public void imp(){
        for(int i = 0 ; i< 10 ; i++){
            Emp emp = new Emp();
            if(i == 3){
                throw new RuntimeException("我出错啦");
            }
            emp.setComm(0f);
            emp.setEname("laoqi" + i);
            emp.setHiredate(new Date());
            emp.setJob("Teacher");
            emp.setMgr(null);
            emp.setSal(i*10f);
            Dept d = deptRepository.findById(20).get();
            emp.setDept(d);
            //saveAndFlush立即执行
            empRepository.saveAndFlush(emp);
        }

@Transactional()参数说明

  1. @Transactional 不写参数的情况下,开启事务,imp方法运行成功提交。运行失败抛出RuntimeException及其子类的时候回滚
  2. @Transactional(rollbackFor = Exception.class)将回滚异常的级别提高的Exception级别,一般用该参数,比较稳妥,避免framework级别异常导致的回滚失败
  3. @Transactional(propagation = Propagation.NOT_SUPPORTED , readOnly = true)//不开启事务的方法

其他说明

  1. @Transactional为org.framework.transactional,而不是javax.transactional

  2. 一般情况下,事务注解要写在最核心的Service上,而不是Controller

  3. 可以在类的级别上,说明事务,说明该类下的所有方法都开启事务
    示例:

    @Transactional(rollbackFor = Exception.class)
    public class EmpController {
    @Autowired
    private EmpRepository empRepository;
    @Autowired
    private DeptRepository deptRepository;
    @GetMapping("/{id}")
    public Emp findById(@PathVariable(“id”) Integer id){
    return empRepository.findById(id).get();
    }
    @GetMapping("/create")
    public Emp create(){
    Emp emp = new Emp();
    emp.setComm(0f);
    emp.setEname(“laoqi”);
    emp.setHiredate(new Date());
    emp.setJob(“Teacher”);
    emp.setMgr(null);
    emp.setSal(0f);
    Dept d = deptRepository.findById(20).get();
    emp.setDept(d);
    empRepository.save(emp);
    return emp;
    }

    @GetMapping("/find")
    @Transactional(propagation = Propagation.NOT_SUPPORTED , readOnly = true)//不开启事务的方法
    public List<Emp> find(Integer deptno){
        return empRepository.findEmps(deptno);
    }
    
    @GetMapping("/imp")
    //在默认情况下,数据库的事物作用范围是在JpaRepository的CRUD方法上,
    //save方法一旦执行成功马上提交
    //要保证数据的完整性,那就需要将事务提高至imp方法上
    //在imp方法上开启事务,是需要增加@Transactional
    
    //针对于这种使用注解的事务形式,也有一个名词叫做"声明式事务" , ParseException
    //一般情况下,事务注解要写在最核心的Service上,而不是Controller
    @Transactional(rollbackFor = Exception.class)//开启事务,imp方法运行成功提交。运行失败抛出RuntimeException及其子类的时候回滚
    public void imp(){
        for(int i = 0 ; i< 10 ; i++){
            Emp emp = new Emp();
            if(i == 3){
                throw new RuntimeException("我出错啦");
            }
            emp.setComm(0f);
            emp.setEname("laoqi" + i);
            emp.setHiredate(new Date());
            emp.setJob("Teacher");
            emp.setMgr(null);
            emp.setSal(i*10f);
            Dept d = deptRepository.findById(20).get();
            emp.setDept(d);
            //saveAndFlush立即执行
            empRepository.saveAndFlush(emp);
        }
    }
    

    }

  4. 在类上声明事务后,又在类中的方法上声明了事务,最后生效的以最近的事务声明为准,即在方法上的事务声明会生效。

SpringBoot配置全局事务需要使用Spring的事务管理器和注解@Transactional。下面是一个简单的全局事务配置示例: 1. 配置数据源 在application.properties文件配置数据源相关信息: ``` spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3306/test spring.datasource.username=root spring.datasource.password=root ``` 2. 配置事务管理器 创建一个配置类,配置事务管理器: ```java @Configuration @EnableTransactionManagement public class TransactionConfig { @Bean(name = "transactionManager") public PlatformTransactionManager transactionManager(DataSource dataSource) { return new DataSourceTransactionManager(dataSource); } } ``` 3. 开启全局事务 在需要开启事务的方法上添加@Transactional注解即可: ```java @Service public class UserServiceImpl implements UserService { @Autowired private UserDao userDao; @Transactional public void addUser(User user) { userDao.addUser(user); } } ``` 其@Transactional注解的属性可以根据需要进行配置,例如: - propagation:事务的传播行为,默认值为REQUIRED。 - isolation:事务的隔离级别,默认值为DEFAULT。 - readOnly:指定事务是否为只读,默认值为false。 - timeout:指定事务的超时时间,默认值为-1(表示使用数据库默认超时时间)。 这样配置之后,当执行addUser方法时,如果出现异常或者抛出RuntimeException,则整个方法会进行回滚,保证数据一致性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值