@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

相关推荐
heimeiyingwang19 小时前
企业供应链 AI 优化:需求预测与智能调度
大数据·数据库·人工智能·机器学习
山岚的运维笔记20 小时前
SQL Server笔记 -- 第73章:排序/对行进行排序
数据库·笔记·后端·sql·microsoft·sqlserver
XLYcmy20 小时前
智能体大赛 目录
数据库·ai·llm·prompt·agent·检索·万方
盟接之桥20 小时前
盟接之桥EDI软件:API数据采集模块深度解析,打造企业数据协同新引擎
java·运维·服务器·网络·数据库·人工智能·制造
闲人编程21 小时前
内存数据库性能调优
数据库·redis·字符串·高并发·哈希·内存碎片
l1t21 小时前
DeepSeek总结的PostgreSQL 19新功能:第一部分
数据库·postgresql
青衫码上行1 天前
高频 SQL 50题(基础版)| 查询 + 连接
数据库·sql·学习·mysql
Anastasiozzzz1 天前
阿亮随手记:动态条件生成Bean
java·前端·数据库
iameyama1 天前
python Pandas 开发
数据库
Highcharts.js1 天前
数据之美:用Highcharts打造专业级弧线图
javascript·数据库·highcharts·图表开发·弧线图