在spring中@Transactional注解事务失效的几种可能

本文探讨了一种特殊的@Transactional注解失效情况,即由于使用不支持事务的MyISAM引擎导致的问题,并提供了两种解决方法:一是直接修改表引擎为InnoDB;二是通过配置将默认引擎设置为支持事务的类型。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

之前一段测试代码@Transactional注解失效,报错不回滚。百度查了很多资料,大家给出的经验大概是以下三点:

1.同一个类中,没有@Transactional注解的方法去调用有@Transactional注解

2. @Transactional注解修饰的方法不是public的(private)

3 .抛出的异常为checked类型

但是今天本人遇到的都不是上面三种,特此补充。

事务失效最终原因:jpa生成数据表的引擎类型不支持事务,如 MyISAM引擎

解决方案:

       第一种:直接改表,在表设计选项中,将其改为支持事务的引擎,如InnoDB。

       第二种:jpa生成数据表之前,修改默认配置,将其引擎修改为支持事务。

总结:两种办法差不多,因个人开发习惯和公司开发规范而定


 

 

 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值