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);
}

调用接口(预期回滚)

如下所示,数据没有变化

删除事务管理器

构建异常

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

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

相关推荐
叫致寒吧2 小时前
Tomcat详解
java·tomcat
S***26756 小时前
基于SpringBoot和Leaflet的行政区划地图掩膜效果实战
java·spring boot·后端
马剑威(威哥爱编程)6 小时前
鸿蒙6开发视频播放器的屏幕方向适配问题
java·音视频·harmonyos
JIngJaneIL7 小时前
社区互助|社区交易|基于springboot+vue的社区互助交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·社区互助
V***u4537 小时前
MS SQL Server partition by 函数实战二 编排考场人员
java·服务器·开发语言
这是程序猿7 小时前
基于java的ssm框架旅游在线平台
java·开发语言·spring boot·spring·旅游·旅游在线平台
i***t9198 小时前
基于SpringBoot和PostGIS的云南与缅甸的千里边境线实战
java·spring boot·spring
k***08298 小时前
【监控】spring actuator源码速读
java·spring boot·spring
麦麦鸡腿堡8 小时前
Java_网络编程_InetAddress类与Socket类
java·服务器·网络
一 乐8 小时前
应急知识学习|基于springboot+vue的应急知识学习系统(源码+数据库+文档)
数据库·vue.js·spring boot