一、结论
Spring的事务管理默认只对出现运行期异常(java.lang.RuntimeException及其子类)和Error时进行回滚。如果一个方法抛出Checked异常,Spring事务管理默认不进行回滚。
rolling back on RuntimeException and Error but not on checked exceptions
关于异常的分类一下详细介绍:
1、基本概念
看java的异常结构图
Throwable是所有异常的根,java.lang.Throwable
Error是错误,java.lang.Error
Exception是异常,java.lang.Exception
2、Exception
Exception 中的异常一般分为运行时异常(RuntimException)和非运行时异常 (编译异常):
运行时异常(RuntimException):
所有RuntimeException类及其子类的实例被称为运行时异常(RuntimException)。
非运行时异常 (编译异常):
而RuntimeException以外的异常,类型上还都属于Exception类及其子类的异常。我们称作非运行时异常 (编译异常):
关于异常分类中的检查异常和非检查异常。
3、Error
当程序发生不可控的错误时,通常做法是通知用户并中止程序的执行。与异常不同的是Error及其子类的对象不应被抛出。
Error是throwable的子类,代表编译时间和系统错误,用于指示合理的应用程序不应该试图捕获的严重问题。
Error由Java虚拟机生成并抛出,包括动态链接失败,虚拟机错误等。程序对其不做处理。
二、改变默认方式!!!!
在 @Transactional 注解中定义noRollbackFor和rollbackFor指定某种异常是否回滚。
// 对什么类型的不回滚
@Transactional(noRollbackFor = RuntimeException.class)
// 对什么类型的回滚
@Transactional(rollbackFor() = Exception.class)
这样就改变了默认的事务处理方式。
三、启示
这就要求我们在自定义异常的时候,让自定义的异常继承自RuntimeException,这样抛出的时候才会被Spring默认的事务处理准确处理。
参考自!:http://www.jb51.net/article/32246.htm
做了写修改和修正