@Transactional注解详解与应用

介绍

@Transactional注解是Spring框架用于简化声明式事务管理的关键元素。它允许开发者通过简单的注解来控制事务的边界,而无需编写具体的事务管理代码。
用途:用于指定一个方法或类在执行时需要进行事务管理。
位置:

  • 类级别:应用于类上时,表示该类中的所有公共方法(public methods)都将自动加入事务管理。类级别的设置可以被方法级别的设置覆盖。
  • 方法级别:更精确地控制事务边界,仅应用于特定方法。方法级别上的设置优先于类级别设置。

重要参数
尽管@Transactional可以不带任何参数直接使用,默认情况下它具有一定的行为,但也可以通过参数来调整其行为,包括但不限于:

  • value 或transactionManager:指定使用的事务管理器的名称。如果不指定,默认使用配置的事务管理器。
  • propagation:事务传播行为,默认为`REQUIRED`,表示如果当前存在事务,则加入当前事务;如果不存在,则新建一个事务。
  • isolation:事务的隔离级别,默认由数据库决定。
  • readOnly:指示事务是否只读,默认为`false`,表明事务可读写。设为`true`可以优化性能,因为某些数据库在只读事务中可以采取优化措施。
  • timeout:事务超时时间,默认无限制。单位是秒。
  • rollbackFor:指定需要进行回滚的异常类型数组。当方法抛出的异常匹配指定的异常类型时,事务将回滚。
  • noRollbackFor:指定不需要进行回滚的异常类型数组。即使方法抛出这些异常,事务也不会回滚。

行为特点

  • 作用域:`@Transactional`注解只能应用在**public**方法上。应用在protected、private或其他访问修饰符的方法上时,注解将被忽略。
  • 异常处理:默认情况下,只有未被捕获的`RuntimeException`及其子类和`Error`才会导致事务回滚。对于已检查异常(checked exceptions),需通过`rollbackFor`属性显式指定才触发回滚。
  • 代理和AOP:事务管理是通过Spring的AOP(面向切面编程)实现的,因此只有通过Spring代理的对象调用事务方法时,事务才生效。这意味着在同一个类内的方法调用不会触发事务行为。

使用建议

  • 服务层应用:通常建议在业务服务层(如Service层)使用`@Transactional`注解,而不是在数据访问对象(DAO)或控制器层,因为事务管理更多关联于业务逻辑而非数据访问细节。
  • 谨慎使用:虽然`@Transactional`简化了事务管理,但过度或不当使用可能导致难以预料的行为,比如事务过于宽泛或过于细碎,都可能影响性能或数据一致性。

实际应用

在实际应用中,在ServiceImpl层中的public方法上,添加 @Transactional(rollbackFor = Exception.class),若代码抛出任何类型的异常(Exception)(通过rollbackFor = Exception.class指定),那么事务将会被回滚,这意味着在该方法中执行的所有数据库操作都将被撤销,确保数据的完整性。

    @Transactional(rollbackFor = Exception.class)
    @Override
    public String importFile(MultipartFile file, String nickName) {
        //采用easyExcel导入并解析模版中的数据
        List<PriceValve> valves = FileUtil.importExcel(file, 0, 1, PriceValve.class);
        if (CollectionUtils.isEmpty(valves)) {
            return "参数为空,导入失败";
        }
        for (PriceValve valve : valves) {
            valve.setCreateBy(nickName);
            //对数据查重后再新增
            String result = insertValve(valve);
            if (!StringUtils.isEmpty(result)) {
                //抛出异常,事务管理器捕捉并回滚数据
                throw new RuntimeException(result);
            }
        }
        return null;
    }
    @Override
    public String insertValve(PriceValve priceValve) {
        //根据型号和等级查找详情,判断是否有重复(实体类已对字段判空)
        Integer count = priceValveMapper.distinctValve(priceValve);
        if (count != 0) {
            return "型号:" + priceValve.getName() + ",尺寸:" + priceValve.getDn() + ",类型:" + priceValve.getType()
                    + ",等级:" + priceValve.getPn() + "数据已存在,请检查数据后重新存储";
        }
        priceValve.setCreateTime(new Date());
        priceValveMapper.insert(priceValve);
        return null;
    }

  • 19
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
@Transactional是Spring框架中用于管理事务的注解。通过在方法或类上添加@Transactional注解,可以将方法或类标记为一个事务处理单元,使得该方法或类中的数据库操作具有事务性。 @Transactional注解可以应用于方法级别和类级别。当应用于方法级别时,该方法内的所有数据库操作都将作为一个事务进行管理;当应用于类级别时,该类中的所有方法都将作为一个事务进行管理。 使用@Transactional注解时,需要配置事务管理器(Transaction Manager),以便Spring能够正确地管理事务。事务管理器负责开启、提交或回滚事务,并确保数据库操作的一致性和完整性。 以下是@Transactional使用的详解: 1. 在方法上使用@Transactional注解: - 当@Transactional注解应用于方法上时,该方法内的所有数据库操作将作为一个事务进行管理。 - 如果方法执行成功,则事务将被提交,所有数据库操作将永久保存到数据库中。 - 如果方法执行失败,则事务将被回滚,所有数据库操作将被撤销。 - 可以通过设置rollbackFor属性来指定哪些异常触发事务回滚,默认情况下,Spring只会在遇到RuntimeException及其子类时回滚事务。 - 可以通过设置noRollbackFor属性来指定哪些异常不触发事务回滚。 2. 在类上使用@Transactional注解: - 当@Transactional注解应用于类上时,该类中的所有方法都将作为一个事务进行管理。 - 类级别的@Transactional注解可以覆盖方法级别的@Transactional注解,即如果类级别的注解设置了某些属性,那么该类中的所有方法都将继承这些属性。 3. 事务传播行为(Propagation): - 事务传播行为定义了在多个事务方法相互调用时,事务如何传播的规则。 - Spring提供了多种事务传播行为,如REQUIRED、REQUIRES_NEW、NESTED等。 - REQUIRED是默认的传播行为,表示如果当前存在事务,则加入该事务;如果当前没有事务,则创建一个新的事务。 - REQUIRES_NEW表示每次都创建一个新的事务,如果当前存在事务,则将其挂起。 - NESTED表示在当前事务内部创建一个嵌套事务,如果当前不存在事务,则创建一个新的事务。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值