Spring Boot 2.x 编写 RESTful API (六) 事务
Transactional
判定顺序
propagation
isolation
脏读
不可重复读
幻读
不可重复读是指记录不同 (update),幻读是数据条数不同 (insert, delete)
几种隔离的比较
isolation vs. lock
- 两个不同的东西,隔离不是靠锁实现的,是靠对数据的监控实现的
- 锁:表加好锁了,除非出现死锁等特殊状况,事务是不会被数据库主动回滚的
- 隔离:如果发现数据不符合相应的事务隔离级别,当前事务会出错并回滚;相比锁被回滚可能较大,需要程序有出错重试的步骤
timeout
- timeout 事务的超时时间,默认值为 -1。如果超过该时间限制但事务还没有完成,则自动回滚事务
- 方法抛出异常,事务被回滚,可能是 SQL 执行时间过长的异常,也可能是 TransactionTimedOutException
- 从方法执行开始计算,每个 SQL 执行前检查一次是否超时,方法全部执行完毕后不检查是否超时