@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

相关推荐
数据知道8 小时前
PostgreSQL性能优化:内存配置优化(shared_buffers与work_mem的黄金比例)
数据库·postgresql·性能优化
静听山水8 小时前
Redis核心数据结构
数据结构·数据库·redis
流㶡8 小时前
MySQL 常用操作指南(Shell 环境)
数据库
数据知道8 小时前
PostgreSQL 性能优化:连接数过多的原因分析与连接池方案
数据库·postgresql·性能优化
怣508 小时前
MySQL子查询实战指南:数据操作(增删改查)与通用表达式
数据库·chrome·mysql
范纹杉想快点毕业8 小时前
从单片机基础到程序框架:构建嵌入式系统的完整路径
数据库·mongodb
数据知道8 小时前
PostgreSQL性能优化:如何定期清理无用索引以释放磁盘空间(索引膨胀监控)
数据库·postgresql·性能优化
喵叔哟8 小时前
67.【.NET8 实战--孢子记账--从单体到微服务--转向微服务】--新增功能--分摊功能总体设计与业务流程
数据库·微服务·架构
tryCbest8 小时前
Oracle查看存储过程
数据库·oracle
咩咩不吃草8 小时前
【MySQL】表和列、增删改查语句及数据类型约束详解
数据库·mysql·语法