@Transactional注解:是否使用rollbackFor=Exception.class的差异分析
需积分: 0 74 浏览量
更新于2024-08-03
收藏 1.02MB PDF 举报
本文主要探讨了在Java编程中使用`@Transactional`注解时,是否加上`rollbackFor = Exception.class`的区别。首先,作者通过一个实际场景介绍背景,即在一个Mysql数据库环境中,尝试更新一条数据的`delflag`字段为0。为了测试`@Transactional`的行为,作者编写了一个方法,该方法尝试除以0,这肯定会抛出`ArithmeticException`,这是一个`RuntimeException`的子类。
当不添加`rollbackFor = Exception.class`时,`@Transactional`默认处理的是`RuntimeException`及其子类。由于`ArithmeticException`属于这个范围,所以在方法执行时遇到异常后,事务会被自动回滚,导致数据库的更新操作并未完成,`delflag`字段保持不变。
接下来,作者展示了另一种情况,即明确指定`rollbackFor = Exception.class`。这将允许`@Transactional`处理更广泛的异常类型,不仅仅是`RuntimeException`,而是所有继承自`Exception`的异常。在这个例子中,他们故意引发一个`Exception`类型的异常,而不是`RuntimeException`,尽管没有指定具体异常类型,但由于`Exception`是一个超类,所以这次事务也会回滚,数据同样不会被修改。
总结起来,不加`rollbackFor = Exception.class`时,`@Transactional`只会对`RuntimeException`及其子类进行回滚,而加上后则可以处理整个`Exception`类及其子类,增加了事务管理的灵活性。这种理解对于理解和控制Spring框架中的事务行为至关重要,尤其是在分布式系统或需要精细控制事务处理的应用中。
259 浏览量
156 浏览量
2024-12-12 上传
2023-09-14 上传
106 浏览量
2024-09-10 上传
2024-08-01 上传
2023-05-29 上传
101 浏览量
![](https://profile-avatar.csdnimg.cn/1ad39e95093044228d03f0d7ce161a82_zy_dreamer.jpg!1)
![](https://csdnimg.cn/release/wenkucmsfe/public/img/user-vip.1c89f3c5.png)
白话机器学习
- 粉丝: 1w+
最新资源
- OpenGL资源更新:GLTools与GLut的集成
- Unity性能优化:GameTerrain2Mesh高效地形转换工具
- 兔子主题新标签页插件:动物壁纸与实用功能
- 解析通勤人群来源:火车、地铁、公交数据分析
- 简约风格响应式Ultra博客主题源码发布
- 三星SRP-770II打印机官方驱动v5.1.12版本发布
- ES6特性详解与前端开发实践指南
- 轻松解决SD卡无法识别容量及数据恢复问题
- ns2仿真实验全集:多媒体与无线网络通信源代码
- 深入探讨Java编程语言的发展历程
- 深入解析Angular Bootstrap模块的使用与实践
- Android MVP模式实践教程与案例分析
- 实达StartBP-3000xe打印机驱动下载及性能特点解析
- 最新版Liquid Volume Pro 1.3.2Unity插件评测
- Tarea-4:大数据活动中心的关键R编程练习
- 193 Apisoft VB:全面数据分析解决方案