五种隔离级别
在TransactionDefinition接口中定义
- ISOLATION_DEFAULT
使用后端数据库默认的隔离级别 - ISOLATION_READ_UNCOMMITTED
最低的隔离级别,允许读取尚未提交的数据变更,可能会导致脏读,幻读,或不可重复读。 - ISOLATION_READ_COMMITTED
读取已提交的数据,可以解决脏读问题 - ISOLATION_REPEATABLE_READ
对同一字段的多次读取结果都是一致的,除非数据是被事务自身修改,可以解决脏读和不可重复读问题 - ISOLATION_SERIALIZABLE
所有事务依次逐个执行,可以解决脏读、不可重复读和幻读。
比Mysql的隔离级别多一种default。
事务传播行为(7种)
支持当前事务:
如果当前存在事务,则加入该事务
1. PROPAGATION_REQUIRED:
如果当前没有事务,则创建一个新事务
2. PROPAGATION_SUPPORTS:
如果当前没有事务,则以非事务的方式继续运行
3. PROPAGATION_MANDATORY:
如果当前没有事务,则抛出异常
不支持当前事务:
4. PROPAGATION_REQUIRES_NEW:
创建一个新的事务,如果当前存在事务,则把当前事务挂起
5. PROPAGATION_NOT_SUPPORTED:
以非事务方式运行,如果当前存在事务,则把当前事务挂起
6. PROPAGATION_NEVER:
以非事务方式运行,如果当前存在事务,则抛出异常。
其他:
7. PROPAGATION_NESTED:
如果当前存在事务,则创建一个事务作为当前事务的嵌套事务来运行;如果当前没有事务,则该取值等价于REQUIRED,也就是创建一个新事务。
参考资料
JavaGuide