SpringBoot的事务处理

全局的事务处理

使用方法

特别提醒:mysql对应的表必须是InnoDB型才可支持事务,myisam不支持事务
导入springboot的aop依赖

<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-aop</artifactId>
</dependency>

创建一个全局事务处理的配置类
这里注意2点:

  • execution的内容
execution(* com..service..*.*(..))
  • 使用TransactionManager,使用这个类的时候不会报过时警告,PlatformTransactionManager会有过时警告
  • service层记得打@Service注解
@Aspect
@Configuration
public class TransactionAdviceConfig {
private static final String AOP_POINTCUT_EXPRESSION = "execution(* com..service..*.*(..))";

    @Autowired
    private TransactionManager transactionManager;

    @Bean
    public TransactionInterceptor txAdvice() {

        DefaultTransactionAttribute txAttr_REQUIRED = new DefaultTransactionAttribute();
        txAttr_REQUIRED.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);

        DefaultTransactionAttribute txAttr_REQUIRED_READONLY = new DefaultTransactionAttribute();
        txAttr_REQUIRED_READONLY.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);
        txAttr_REQUIRED_READONLY.setReadOnly(true);

        NameMatchTransactionAttributeSource source = new NameMatchTransactionAttributeSource();

        source.addTransactionalMethod("save*", txAttr_REQUIRED);
        source.addTransactionalMethod("delete*", txAttr_REQUIRED);
        source.addTransactionalMethod("update*", txAttr_REQUIRED);
        source.addTransactionalMethod("exec*", txAttr_REQUIRED);
        source.addTransactionalMethod("set*", txAttr_REQUIRED);
        source.addTransactionalMethod("get*", txAttr_REQUIRED_READONLY);
        source.addTransactionalMethod("query*", txAttr_REQUIRED_READONLY);
        source.addTransactionalMethod("select*", txAttr_REQUIRED_READONLY);
        source.addTransactionalMethod("find*", txAttr_REQUIRED_READONLY);
        source.addTransactionalMethod("list*", txAttr_REQUIRED_READONLY);
        source.addTransactionalMethod("count*", txAttr_REQUIRED_READONLY);
        source.addTransactionalMethod("is*", txAttr_REQUIRED_READONLY);

        return new TransactionInterceptor(transactionManager, source);
    }

    @Bean
    public Advisor txAdviceAdvisor() {
        AspectJExpressionPointcut pointcut = new AspectJExpressionPointcut();
        pointcut.setExpression(AOP_POINTCUT_EXPRESSION);
        return new DefaultPointcutAdvisor(pointcut, txAdvice());
    }
}

然后启动项目运行sql访问,查看控制台信息
Registering transaction synchronization for SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@27ab75b]
JDBC Connection
[com.alibaba.druid.proxy.jdbc.ConnectionProxyImpl@63380d1f] will be managed by Spring
spring管理事务
事务管理完成

在方法上使用@Transactional(rollbackFor = Exception.class)的事务处理方式

使用方法

@Transactional(rollbackFor = Exception.class)
@Service
public class xxxxService {
    @Autowired
    private xxxxMapper xxxxMapper;

    public xxxxServer select(Integer mailId) {
        return xxxxMapper.select(mailId);
    }
}

使用这两种方式基本上可以做到让spring对事务的管控,上述方式如果有不足或者需要补充的地方希望大家提出和交流,一起学习一起成长✌

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Spring Boot 中,事务处理非常简单,只需要添加注解即可。通常情况下,我们使用 @Transactional 注解来标记一个方法需要事务处理。 使用 @Transactional 注解时,需要注意以下几点: 1. 在类或方法上添加 @Transactional 注解,表示该类或方法需要事务处理。 2. 在方法上添加 @Transactional 注解时,默认情况下事务只在抛出 RuntimeException 及其子类异常时回滚。 3. 可以通过设置 rollbackFor 属性来指定需要回滚的异常类型。 4. 事务只在 public 方法上起作用。 5. 如果在一个类的方法中调用另一个方法,被调用的方法上的 @Transactional 注解不会起作用,需要在被调用的方法所在的类上添加 @Transactional 注解。 示例代码如下: ```java @Service public class UserService { @Autowired private UserDao userDao; @Transactional public void save(User user) { userDao.save(user); } @Transactional(propagation = Propagation.REQUIRED, rollbackFor = Exception.class) public void delete(Long id) throws Exception { User user = userDao.findById(id); if (user == null) { throw new Exception("用户不存在"); } userDao.delete(user); } } ``` 在上面的示例代码中,我们定义了两个方法:save 和 delete。在 save 方法上添加了 @Transactional 注解,表示该方法需要事务处理。在 delete 方法上,我们通过设置 propagation 属性来指定事务的传播行为,通过设置 rollbackFor 属性来指定需要回滚的异常类型。 需要注意的是,在使用事务处理时,一定要保证事务的粒度要尽可能小,以减少事务的锁定时间,提高并发性能。同时,对于需要回滚的异常类型,一定要慎重选择,避免将不需要回滚的异常也加入回滚列表中,导致事务回滚过于频繁,影响性能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值