一、使用范围
@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属性:用于设置哪些异常不需要回滚