java事务回滚失败问题分析

2025-05-27 0 45

Spring-Java事物回滚失效处理最近在做项目中,无意间发现有个类在抛事物回滚操作,数据也正常的插入到数据库当中了,于是仔细查看看一下具体原因。

一切还是要从Java的检查型异常和非检查型异常说起。

那么什么是检查型异常什么又是非检查型异常呢?

最简单的判断点有两个:

1.继承自RuntimeException或Error的是非检查型异常,而继承自Exception的则是检查型异常(当然,RuntimeException本身也是Exception的子类)。

2.对非检查型类异常可以不用捕获,而检查型异常则必须用try……catch语句块进行处理或者把异常交给上级方法处理,总之就是必须写代码处理它。

Java的异常结构如下图。其中直接继承Exception的异常,必须捕获,属于检查型异常。

java事务回滚失败问题分析

再回过来看我的代码:

1、方法名前面有

?

1
@Transactional

2、Spring的配置文件applicationContext-XXX.xml当中也有Spring事物的相关配置

?

1

2

3

4

5
<bean id="transactionManager"

class="org.springframework.jdbc.datasource.DataSourceTransactionManager">

<property name="dataSource" ref="dataSource" />

<property name="rollbackOnCommitFailure" value="true"></property>

</bean>

但是为什么在Service层方法调用的时候,try……catch抛Exception异常已经提交的事物却没有回滚

查看相关spring的文档后发现,原来spring声明式事务管理默认对非检查型异常和运行时异常进行事务回滚,而对检查型异常则不进行回滚操作。

代码中try……catch抛出的Exception异常,属于检查型异常,Spring的框架默认是不会进行回滚的。

在编程中对非检查型类异常可以不用捕获,而检查型异常则必须用try语句块进行处理或者把异常交给上级方法处理总之就是必须写代码处理它。

所以必须在service捕获异常,然后再次手动throw一个非检查型异常,这样事务方才起效。例如:

?

1

2

3

4

5

6
try{

…………

} catch (Exception e) {

…………

throw new BusinessException(e.getMessage());

}

当然我们还有更简便的方法来解决这个问题,那就是通过注解参数改变默认的回滚方式。

在@Transaction注解中定义了noRollbackFor和RollbackFor来指定某种异常是否回滚

使用例:

@Transaction(noRollbackFor=RuntimeException.class)

@Transaction(RollbackFor=Exception.class)

所以上述的问题可以直接将@Transaction添加回滚参数@Transaction(RollbackFor=Exception.class),这样就改变了默认的事务处理方式。

启示:

这就要求我们在自定义异常的时候,让自定义的异常继承自RuntimeException,这样抛出的时候才会被Spring默认的事务处理准确处理。

总结

以上就是本文关于java事务回滚失败问题分析的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

原文链接:http://blog.csdn.net/qq_34406670/article/details/78945962

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 java事务回滚失败问题分析 https://www.kuaiidc.com/76641.html

相关文章

发表评论
暂无评论