一、使用范围
@Transactional 注解 可以作用于接口、接口方法、类以及类方法上。
当用作类上时,该类上的所有 public 方法将都具有该类型的属性。
当用作方法上是,该方法所在类上的注解将失效,该注解只能应用在 public 方法上。
不建议用在接口或接口方法上,因为这只有在使用基于接口的动态代理是才会生效
!注意:只有来自外部的方法调用才会引起事务行为,类内部方法调用本类内部的其他方法并不会引起事务行为。
二、注解属性
value属性:当配置多个事务管理器时,可以使用该属性指定选择哪个事务管理器。
propagation属性:用于指定事务的传播行为、默认值为 REQUIRED。
属性 | 含义 |
---|---|
REQUIRED | 如果当前没有事务,就新建一个事务,如果已经存在一个事务,则加入到这个事务中 |
SUPPORTS | 支持当前事务,如果当前没有事务,就以非事务方式执行 |
MANDATORY | 表示当前方法必须在事务中运行。如果当前事务不存在,则会抛出一个异常 |
REQUIRES_NEW | 表示当前方法必须运行在它自己的事务中(一个新的事务将被启动)。如果存在当前事务,在该方法执行期间,当前事务会被挂起 |
NOT_SUPPORTED | 表示该方法不运行在事务中。如果当前存在事务,就把当前事务挂起 |
NEVER | 表示当前方法不应该运行在事务上下文中。如果当前正有一个事务在运行,则会抛出异常 |
NESTED | 如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与REQUIRED类似的操作 |
isolation属性:用于指定事务的隔离规则,默认值为DEFAULT
属性 | 含义 |
---|---|
DEFAULT | 使用后端数据库默认的隔离级别 |
READ_UNCOMMITTED | 允许读取尚未提交的数据变更(最低的隔离级别) |
READ_COMMITTED | 允许读取并发事务已经提交的数据 |
REPEATABLE_READ | 对同一字段的多次读取结果都是一致的,除非数据是被本身事务自己所修改 |
SERIALIZABLE | 完全服从ACID的隔离级别,也是最慢的事务隔离级别,因为它通常是通过完全锁定事务相关的数据库表来实现的(最高的隔离级别) |
timeout 属性:用于设置事务的超时
readOnly 属性:用于设置事务是否只读
rollbackFor 属性、rollbackForClassName 属性:用于设置哪些异常需要回滚
noRollbackFor 属性、noRollbackForClassName 属性:用于设置哪些异常不需要回滚