spring事务注解中timeout配置

要点
Spring事务超时 = 事务开始 到 最后一个Statement创建之间的时间 + 最后一个Statement的执行的时间(即其queryTimeout)


设置@Transactional(timout = 1)时,希望是当前方法在一个事务中,且事务执行时间应小于1秒中,若超过1秒则应抛出异常:
 Transaction timed out: deadline was Mon Jul 05 00:02:18 CST 2021

但这其中有一个坑:

  • case1: 抛出Transaction timed out 异常
    @Transactional(timeout = 1)
    public List<ResourceEntity> findAll2() throws InterruptedException {
        TimeUnit.SECONDS.sleep(2);
        List<ResourceEntity> resourceEntities = resourceMapper.rangeQueryResources(1, 20);
        return resourceEntities;
    }
  • case2: 不会抛出 Transaction timed out 异常
    @Transactional(timeout = 1)
    public List<ResourceEntity> findAll3() throws InterruptedException {
        List<ResourceEntity> resourceEntities = resourceMapper.rangeQueryResources(1, 20);
        TimeUnit.SECONDS.sleep(2);
        return resourceEntities;
    }

case2可能导致代码中的坑,所以在一个事务方法中,在查询数据库之后不要有耗时过高的操作

具体分析可参考:
Spring事务超时时间可能存在的错误认识

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MyBatis事务注解可以通过`@Transactional`注解来使用。使用该注解可以将一个方法标记为需要进行事务管理的方法。 具体使用步骤如下: 1. 首先在pom.xml文件引入Spring事务管理器依赖: ```xml <dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> <version>5.2.1.RELEASE</version> </dependency> ``` 2. 在Spring配置文件配置事务管理器: ```xml <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource"/> </bean> ``` 3. 在需要进行事务管理的方法上添加`@Transactional`注解: ```java @Transactional public void updateOrder(Order order) { // ... } ``` 在这个例子,`updateOrder`方法将被标记为需要进行事务管理的方法。当该方法被调用时,Spring会自动开始一个事务,并在方法执行结束后提交或回滚事务。 需要注意的是,`@Transactional`注解可以标记在类级别或方法级别上。如果将该注解标记在类级别上,则该类所有的方法都将被视为需要进行事务管理的方法。 另外,`@Transactional`注解还支持一些属性,例如`propagation`、`isolation`、`readOnly`、`timeout`等,可以通过这些属性来控制事务的行为。例如: ```java @Transactional(propagation = Propagation.REQUIRES_NEW, isolation = Isolation.READ_COMMITTED) public void updateOrder(Order order) { // ... } ``` 在这个例子,`propagation`属性指定了事务传播行为为`REQUIRES_NEW`,意味着该方法将创建一个新的事务并在执行结束后提交或回滚该事务;`isolation`属性指定了事务隔离级别为`READ_COMMITTED`,表示该事务可读取已提交的数据,但不能读取未提交的数据。 总之,使用`@Transactional`注解可以方便地实现事务管理,提高应用程序的可靠性和性能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值