Spring Boot 使用JPA @Transactional 报错事务不回滚

@Transactional有两个包:

1、org.springframework.transaction.annotation.Transactional;

2、javax.transaction.Transactional;

两个过都试过了,但service层方法上报错后jpa.save方法仍然插入了数据到DB中,没有回滚,看用的mysql(5.7版本)中引擎要是InnoDB才能支持事务,查看了也确实是InnoDB。后来加了如下配置后,事务生效了:

# application.yml

spring:

 jpa: 

 database-platform: org.hibernate.dialect.MySQL5InnoDBDialect #InnoDB才能支持事务

或者

# application.xml
spring.jpa.database-platform=org.hibernate.dialect.MySQL5InnoDBDialect
 

再贴下我的事务配置(org.springframework.transaction.annotation.Transactional)

@Transactional(propagation = Propagation.SUPPORTS, readOnly = false, rollbackFor = Exception.class)

参照:https://blog.csdn.net/equaker/article/details/81534922

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
@Transactional注解在Java中是一个Spring框架提供的用于管理数据库事务的特性。默认情况下,当你在方法使用@Transactional时,Spring会根据配置自动管理数据源事务。具体来说: 1. **自动绑定数据源**:如果方法没有显式指定数据源(例如,`@Transactional(dataSource = "dataSourceName")`),Spring会自动将当前的JdbcTemplate或JpaRepository操作与Spring Boot应用中的默认数据源关联。 2. **隔离级别**:默认情况下,@Transactional使用的是数据库的默认隔离级别,这通常是“READ_COMMITTED”,但可以通过配置更改。 3. **传播行为**:如果在嵌套的方法调用中使用@TransactionalSpring会根据设置的传播行为来决定是否开始新的事务。如果不指定传播行为,默认为支持的传播行为,如PROPAGATION_REQUIRED(如果当前存在事务,则加入;否则新建)。 4. **回滚规则**:如果@Transactional注解的方法抛出异常,除非有rollbackFor或noRollbackFor属性声明特定异常不会导致回滚,否则默认会触发事务回滚。 5. **自提交和传播行为**:若在@Transactional中设置了propagation=Propagation.SUPPORTS或propagation=Propagation.NEVER,那么方法本身不会开始事务,而是依赖于外部事务。 6. **保存点和回滚到保存点**:Spring不直接支持保存点和回滚到保存点,但可以通过编程方式实现。 相关问题-- 1. 如何通过配置文件调整@Transactional的默认行为? 2. 如何在@Transactional中设置具体的传播行为? 3. 除了异常导致回滚,还有哪些情况会触发事务回滚
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值