for循环中循环一次提交一次 insert update 关闭事务 spring springboot mybatis

省流:

在方法上直接加如下注解:

java 复制代码
@Transactional(propagation = Propagation.NOT_SUPPORTED)
public void t1(){
    //业务代码
}

正文:

在测试的时候,有时候会希望在for循环中,代码循环一次就提交一次事务。

方法一:

最简单的方式,就是关闭事务,不需要事务。添加注解如下:

java 复制代码
@Transactional(propagation = Propagation.NOT_SUPPORTED)
public void t1(){
    //业务代码
}

方法二:

如果说是真的在生产上有这样的需要,每循环一次就提交事务,那就需要手动控制事务了。

需要这几行代码:

java 复制代码
            DefaultTransactionDefinition dt = new DefaultTransactionDefinition();
            dt.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRES_NEW);
            TransactionStatus status = platformTransactionManager.getTransaction(dt);
            platformTransactionManager.commit(status);

用法如下:

java 复制代码
    @Autowired
    private PlatformTransactionManager platformTransactionManager;
    
    @Test
    public void t1(){
        for(int i=0; i<list.size(); i++){
            DefaultTransactionDefinition dt = new DefaultTransactionDefinition();
            dt.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRES_NEW);
            TransactionStatus status = platformTransactionManager.getTransaction(dt);
            mapper.select(o);
            mapper.insert(o);
            platformTransactionManager.commit(status);
        }
    }

具体解读请前往以下两篇文章:

Transactional的7种Propagation:

spring springboot mybatis 事务配置 Transactional的Propagation 开启事务 关闭事务_globalcoding的博客

开启和关闭事务时sqlsession创建机制,手动控制事务时sqlsession 创建机制:

spring springboot mybatis transaction 开启事务 关闭事务 不使用事务_globalcoding的博客

=====================分割线=========================

文章到此已经结束,以下是紫薯补丁

@Transactional(propagation = Propagation.NOT_SUPPORTED)

public void t1(){

//业务代码

}

@Autowired

private PlatformTransactionManager platformTransactionManager;

@Test

public void t1(){

for(int i=0; i<list.size(); i++){

DefaultTransactionDefinition dt = new DefaultTransactionDefinition();

dt.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRES_NEW);

TransactionStatus status = platformTransactionManager.getTransaction(dt);

mapper.select(o);

mapper.insert(o);

platformTransactionManager.commit(status);

}

}

相关推荐
秋意钟3 分钟前
Spring框架处理时间类型格式
java·后端·spring
科马4 小时前
【Redis】缓存
数据库·redis·spring·缓存
cloud___fly4 小时前
Spring AOP入门
java·后端·spring
灰色孤星A5 小时前
瑞吉外卖项目学习笔记(四)@TableField(fill = FieldFill.INSERT)公共字段填充、启用/禁用/修改员工信息
java·学习笔记·springboot·瑞吉外卖·黑马程序员·tablefield·公共字段填充
zxguan6 小时前
Springboot 学习 之 logback-spring.xml 日志压缩 .tmp 临时文件问题
spring boot·学习·spring
繁川7 小时前
深入理解Spring AOP
java·后端·spring
AI人H哥会Java14 小时前
【Spring】Spring的模块架构与生态圈—Spring MVC与Spring WebFlux
java·开发语言·后端·spring·架构
小马爱打代码15 小时前
SpringCloud(注册中心+OpenFeign+网关+配置中心+服务保护+分布式事务)
分布式·spring·spring cloud
Watermelon_Mr15 小时前
Spring(三)-SpringWeb-概述、特点、搭建、运行流程、组件、接受请求、获取请求数据、特殊处理、拦截器
java·后端·spring
岁月变迁呀19 小时前
Spring Cloud Gateway 源码
java·spring·spring cloud·gateway