@transactional事务失效场景

未启用事务管理 Spring Boot应用中需通过@EnableTransactionManagement显式启用事务管理(但多数情况下默认自动配置已启用)。检查配置类或主启动类是否遗漏该注解。

方法访问权限问题 @Transactional注解仅对public方法有效。若方法为privateprotected或包级私有,事务将不生效。确保目标方法为public修饰。

自调用问题 类内部方法A调用带有@Transactional的方法B时,由于代理机制绕过Spring AOP,事务不生效。需通过依赖注入自身代理或拆分到不同类解决。

异常类型不匹配 默认仅对RuntimeExceptionError回滚。若捕获了异常未抛出或抛出检查异常(如IOException),需配置rollbackFor属性:

复制代码
@Transactional(rollbackFor = Exception.class)

数据库引擎不支持 使用MyISAM等不支持事务的存储引擎会导致失效。确认数据库表使用InnoDB引擎:

复制代码
SHOW TABLE STATUS LIKE 'table_name';

多数据源未指定 多数据源环境下需明确指定事务管理器。通过transactionManager属性指定:

复制代码
@Transactional(value = "specificTransactionManager")

传播行为配置不当 PROPAGATION_NOT_SUPPORTED等传播行为会挂起当前事务。根据业务需求调整传播行为:

复制代码
@Transactional(propagation = Propagation.REQUIRED)

异步方法调用 @Async方法内的事务需单独声明,因异步执行在不同线程。确保异步方法本身也有@Transactional注解。

验证事务生效的方法

日志检查 开启Spring事务日志观察事务启停:

复制代码
logging.level.org.springframework.transaction.interceptor=DEBUG

手动回滚测试 在方法中抛出RuntimeException,确认数据是否回滚。这是最直接的验证方式。

数据库连接验证 检查JDBC连接是否设置为自动提交false

复制代码
Connection conn = dataSource.getConnection();
System.out.println(conn.getAutoCommit()); // 应输出false
相关推荐
一个网络学徒2 分钟前
python5
java·服务器·前端
飞升不如收破烂~5 分钟前
Redis 分布式锁+接口幂等性使用+当下流行的限流方案「落地实操」+用户连续点击两下按钮的解决方案自用总结
数据库·redis·分布式
workflower6 分钟前
业务需求-假设场景
java·数据库·测试用例·集成测试·需求分析·模块测试·软件需求
亓才孓21 分钟前
[JDBC]基于三层架构和MVC架构的JDBCTools
数据库
专注VB编程开发20年24 分钟前
vb.net datatable新增数据时改用数组缓存
java·linux·windows
(>_<)27 分钟前
java minio 分片上传工具类与测试demo
java·minio·分片上传
不想打工的码农27 分钟前
MyBatis-Plus多数据源实战:被DBA追着改配置后,我肝出这份避坑指南(附动态切换源码)
java·后端
IT邦德35 分钟前
RPM包快速安装Oracle26ai
数据库·oracle
Dovis(誓平步青云)36 分钟前
《滑动窗口算法:从 “暴力遍历” 到 “线性高效” 的思维跃迁》
运维·服务器·数据库·算法
Coder_Boy_43 分钟前
Deeplearning4j+ Spring Boot 电商用户复购预测案例
java·人工智能·spring boot·后端·spring