@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

相关推荐
whn19772 小时前
【达梦】-544: 超出全局排序空间,请调整SORT_BUF_GLOBAL_SIZE、SORT_BUF_SIZE、SORT_BLK_SIZE
数据库
dc_00122 小时前
MSSQL2022的一个错误:未在本地计算机上注册“Microsoft.ACE.OLEDB.16.0”提供程序
数据库·microsoft
w***71103 小时前
MySQL 事务的操作和四大特性
android·数据库·mysql
p***19943 小时前
MySQL中常见函数
数据库·mysql
m***06683 小时前
MySQL —— 配置文件
数据库·mysql·adb
e***13623 小时前
mysql之日期时间函数
数据库·mysql
heimeiyingwang3 小时前
如何用向量数据库构建企业级语义检索系统
数据库·mongodb·nosql·milvus
Web打印3 小时前
Phpask(php集成环境)之03安装mysql
数据库·mysql
p***19944 小时前
实操解决Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错的问题
数据库·postgresql
xj198603194 小时前
maven导入spring框架
数据库·spring·maven