SpringBoot事务管理+AOP

1.事务是什么?在MySQL中是怎么去开启,提交,回滚事务的。
事务 是一组操作的集合,它是一个不可分割的工作单位,事务会把所有的操作作为一个整体一起向系统提交或撤销操作请求,即这些操作 要么同时成功,要么同时失败。

在MySQL中:

开启事务(一组操作开始前,开启事务):start   transaction / begin ;

提交事务(这组操作全部成功后,提交事务):commit ;

回滚事务(中间任何一个操作出现异常,回滚事务):rollback ;

2.在Spring中怎么管理事务,用什么注解,在那个层次进行使用可以有效管理事务
注解:@Transactional

位置:业务(service)层的方法上、类上、接口上

开启管理日志:

logging:
    level:    
      org.springframework.jdbc.support.JdbcTransactionManager: debug
3.事务管理时规则:如果方法能够正常执行完自动提交事务,如果出现异常自动回滚事物。事务默认识别的异常是运行时异常,如果想要识别到编译时异常从而实现回滚,该怎么操作?
事务管理注解@Transactional中的rollbackFor属性默认情况下,只有出现RuntimeException才回滚异常。而如果出现编译时异常,则不回滚

如果想要实现编译时异常回滚,有两种方法

第一种方法是直接甩锅抛出异常,设置rollbackFor属性值为Exception.class,支持多态
 //    删除部门
    @Override
    @Transactional(rollbackFor = Exception.class)
    public void deleteDept(Integer id) throws FileNotFoundException{
//      删除部门
        deptMapper.deleteById(id);
 
 
//        模拟编译时异常
        new FileInputStream("***/***/***.txt");
 
//        删除该部门对应的员工
        empMapper.deleteByDeptId(id);
    }
第二种方法是使用try,catch语句捕获编译异常,在catch中抛出(throw)运行异常完成转换,从而实现回滚
//    删除部门
    @Override
    @Transactional //Spring事务管理
    public void deleteDept(Integer id){
//      删除部门
        deptMapper.deleteById(id);
 
 

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值