@Transactional使用的注意事项

在项目中涉及到CRUD操作时,一般都会在方法上添加该注解,以为加上@Transactional,Spring就可以自动帮我们进行事务的开启、提交

有一个很多人都会犯的误区:

将Spring事务与@Transactional划上了等号,只要有数据库相关操作就直接给方法加上@Transactional注解

但事实上,还是会有一些坑导致事务失效

@Transactional 事务失效的场景

当声明式事务 @Transactional 遇到以下场景时,事务会失效:

1、非 public 修饰的方法;

2、timeout 设置过小;

3、代码中使用 try/catch 处理异常;

4、调用类内部 @Transactional 方法;

5、数据库不支持事务。

6、没有设置属性rollbackFor = Exception.class

@Transactional只能回滚RuntimeException和RuntimeException下面的子类抛出的异常 不能回滚Exception异常!!!

如果需要支持回滚Exception异常请用@Transactional(rollbackFor = Exception.class),

如果是增删改的时候我建议大家都使用@Transactional(rollbackFor = Exception.class)。

7、@Transactional 注解属性 propagation 设置错误

如果设置的事务传播行为是这三种,发生错误事务将不会回滚:

TransactionDefinition.PROPAGATION_SUPPORTS

TransactionDefinition.PROPAGATION_NOT_SUPPORTED

TransactionDefinition.PROPAGATION_NEVER

相关推荐
SQL必知必会3 分钟前
SQL HAVING 是什么?一篇讲清 WHERE 和 HAVING 的区别
数据库·sql
weixin_568996064 分钟前
c++如何实现日志文件的异步落盘功能_基于无锁队列方案【附代码】
jvm·数据库·python
tongyiixiaohuang15 分钟前
技术案例分享:金蝶云星空客户数据同步到MySQL的实现
android·数据库·mysql
淘矿人31 分钟前
2026年4月-DeepSeek V4 vs GPT-5.5深度对比测评:weelinking一键切换实测
服务器·数据库·人工智能·python·gpt·学习·php
2401_831419441 小时前
CSS 悬停箭头闪烁下移问题的根源与稳定解决方案
jvm·数据库·python
reasonsummer1 小时前
【教学类-160-11】20260419 AI视频培训-练习011“豆包AI视频《佛源植语》+豆包图片风格:无(关键词:藏传唐卡)”
数据库·音视频·豆包
瀚高PG实验室1 小时前
pgroonga全文检索插件的BUG
数据库·postgresql·bug·瀚高数据库
Rick19931 小时前
mysql 慢查询如何快速定位
数据库·mysql
2401_833033621 小时前
c++如何实现简单的文件签名验证_HMAC-SHA1算法应用【进阶】
jvm·数据库·python
qq_392690662 小时前
SQL报表查询标准规范_SQL书写规范优化
jvm·数据库·python