事务的其他属性
隔离级别
- 脏读:
对于两个事物 T1, T2, T1 读取了已经被 T2 更新但 还没有被提交的字段. 之后, 若 T2 回滚, T1读取的内容就是临时且无效的. - 不可重复读:
对于两个事物 T1, T2, T1 读取了一个字段, 然后 T2 更新了该字段. 之后, T1再次读取同一个字段, 值就不同了. - 幻读:
对于两个事物 T1, T2, T1 从一个表中读取了一个字段, 然后 T2 在该表中插入了一些新的行. 之后, 如果 T1 再次读取同一个表, 就会多出几行.
隔离级别 | 描述 |
---|---|
DEFAULT | 使用底层数据库的默认隔离级别。对于大多数数据库来说,默认隔离级别都是READ_COMMTED |
READ_UNCOMMTTED | 允许事务读取未被其他事务提交 的变更。脏读,不可重复读和幻读的问题都会出现 |
READ_COMMTED | 只允许事务读取已经被其他事务提交的变更。可以避免脏读,但不可重复读和幻读问题仍然可以出现 |
REPEATABLE_READ | 确保事务可以多次从一个字段中读取相同的值。在这个事务持续期间,禁止其他事务对这个字段进行更新,可以便面脏读和不可重复读,但幻读的问题仍然存在。 |
SERIALIZABLE | 确保事务可以从一个表中读取相同的行。在这个事务持续期间,禁止其他事务对该表执行插入,更新和删除操作,所有并发问题都可以避免,但性能十分低下。 |
BookShopServiceImpl.java(com.test.spring.tx.BookShopServiceImpl)
// 使用 isolation 指定事务的隔离级别,最常用的取值为 READ_COMMITTED
@Transactional(propagation = Propagation.NOT_SUPPORTED,
isolation = Isolation.READ_COMMITTED)
@Override
public void purchase(String username, String isbn) {}
回滚
事务的回滚规则可以通过 @Transactional 注解的 rollbackFor 和 noRollbackFor 属性来定义. 这两个属性被声明为 Class[] 类型的, 因此可以为这两个属性指定多个异常类.
BookShopServiceImpl.java(com.test.spring.tx.BookShopServiceImpl)
// 默认情况下 Spring 的声明式事务对所有的运行时异常进行回滚,
// 也可以通过对应的属性进行设置,通常情况下取默认值即可
@Transactional(propagation = Propagation.NOT_SUPPORTED,
isolation = Isolation.READ_COMMITTED,
noRollbackFor = {UserAccountException.class})
@Override
public void purchase(String username, String isbn) {}
过期
事务在强制回滚之前可以保持多久. 这样可以防止长期运行的事务占用资源.
BookShopServiceImpl.java(com.test.spring.tx.BookShopServiceImpl)
// 使用 timeout 指定强制回滚之前事务可以占用的时间。
@Transactional(propagation = Propagation.NOT_SUPPORTED,
isolation = Isolation.READ_COMMITTED,
readOnly = false,
timeout = 3)
@Override
public void purchase(String username, String isbn) {}
只读
表示这个事务只读取数据但不更新数据, 这样可以帮助数据库引擎优化事务.
BookShopServiceImpl.java(com.test.spring.tx.BookShopServiceImpl)
// 使用 readOnly 指定事务是否为只读,表示这个事务只读取数据但不更新数据,
// 这样可以帮助数据库引擎优化事务,若是一个只读取数据库值的方法,应设置 readOnly = true
@Transactional(propagation = Propagation.NOT_SUPPORTED,
isolation = Isolation.READ_COMMITTED,
readOnly = false)
@Override
public void purchase(String username, String isbn) {}