springboot jpa手动事务

创建springboot项目

搭建最简单的SpringBoot项目_Steven-Russell的博客-CSDN博客

引入jpa和数据据依赖

复制代码
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.33</version>
</dependency>
复制代码
<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <version>1.18.28</version>
    <scope>provided</scope>
</dependency>

创建实体类

复制代码
@Data
@Entity
@Table(name = "tbl_user")
public class User {

    @Id
    @Column
    @GeneratedValue
    private int id;

    @Column
    private String name;

    @Column
    private String addr;

    @UpdateTimestamp
    @Column
    private Date updateTime;
}

创建Repository

复制代码
public interface UserRepository extends CrudRepository<User, Integer> {
     @Transactional
     @Modifying
     int deleteAllByNameIn(@Param(value = "nameList") List<String> nameList);
}

创建controller 并且注入 事务管理器和Repository

注意:需要注入 PlatformTransactionManager

创建数据

构建异常

复制代码
@GetMapping(value = "transactional")
public String transactionalUser() {
    DefaultTransactionDefinition transDefinition = new DefaultTransactionDefinition();
    transDefinition.setPropagationBehavior(DefaultTransactionDefinition.PROPAGATION_REQUIRES_NEW);
    TransactionStatus transStatus = transactionManager.getTransaction(transDefinition);
    try {
        deleteUser4Transactional();
        addUser4Transactional();
        transactionManager.commit(transStatus);
    } catch (Exception e) {
        e.printStackTrace();
        transactionManager.rollback(transStatus);
    }

    return "success";
}

private void addUser4Transactional() {
    int i = 1;
    int ans = i/0;
    User user = new User();
    user.setName("addUser4TransactionalName");
    user.setAddr("chongqing");
    userRepository.save(user);
}

private void deleteUser4Transactional() {
    List<String> nameList = new ArrayList<String>(){{
        add("aaa");
        add("ccc");
    }};
    int ans = userRepository.deleteAllByNameIn(nameList);
    System.out.println("deleteUser4Transactional ans : " + ans);
}

调用接口(预期回滚)

如下所示,数据没有变化

删除事务管理器

构建异常

调用接口(异常之前的操作被正常提交,并没有被回滚)

发现数据已经被删除,但是异常之后的添加操作并没有生效提交

相关推荐
Java 码农23 分钟前
Centos7 maven 安装
java·python·centos·maven
涵涵(互关)28 分钟前
Maven多模块项目MyMetaObjectHandler自动填充日期未生效
spring·maven·mybatis
harmful_sheep32 分钟前
maven mvn 安装自定义 jar 包
java·maven·jar
007php0071 小时前
某大厂跳动面试:计算机网络相关问题解析与总结
java·开发语言·学习·计算机网络·mysql·面试·职场和发展
JH30731 小时前
第七篇:Buffer Pool 与 InnoDB 其他组件的协作
java·数据库·mysql·oracle
皮皮林5512 小时前
订单分库分表后,商家如何高效的查询?
java
Roye_ack3 小时前
【项目实战 Day12】springboot + vue 苍穹外卖系统(Apache POI + 工作台模块 + Excel表格导出 完结)
java·spring boot·后端·excel·苍穹外卖
qq_5470261793 小时前
SpringBoot+Redis实现电商秒杀方案
spring boot·redis·后端
程序猿DD4 小时前
如何在 Spring Boot 应用中配置多个 Spring AI 的 LLM 客户端
spring boot·llm·spring ai