前言
Spring的事务,也就是数据库的事务操作,符合ACID标准,也具有标准的事务隔离级别,所以Spring的事务隔离级别和事务的传播行为是面试中经常考察的问题,下面简单做下总结
事务并发引发的问题
- 脏读: 一个事务读取到了另一个事务修改但还未提交的数据
- 不可重复读:一个事务读取数据之后,该数据被其他事务修改,此时第一个事务再读数据可能不一致(强调改)
- 幻读:一个事务读取了某些数据,没提交再读取时数据多了或者少了,类似幻觉(强调增删)
- 丢失修改: 两个事务都读取了数据,其中一个事务修改之后,另一个事务也做了修改,前者的修改丢失
7种事务传播特性
- PROPAGATION_REQUIRED :如果当前没有事务,就新建一个事务,如果已存在一个事务中,加入到这个事务中,这是Spring默认的选择
- PROPAGATION_SUPPORTS :支持当前事务,如果没有当前事务,就以非事务方法执行
- PROPAGATION_MANDATORY :使用当前事务,如果没有当前事务,就抛出异常
- PROPAGATION_REQUIRES_NEW :新建事务,如果当前存在事务,把当前事务挂起
- PROPAGATION_NOT_SUPPORTED :以非事务方式执行操作,如果当前存在事务,就把当前事务挂起
- PROPAGATION_NEVER :以非事务方式执行操作,如果当前事务存在则抛出异常
- PROPAGATION_NESTED :如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与propagation_required类似的操作
5种事务的隔离级别
- ISOLATION_DEFAULT :默认的隔离级别,使用数据库默认的事务隔离级别
- ISOLATION_READ_UNCOMMITTED :最低的事务隔离级别,它允许另外一个事务可以看到这个事务未提交的数据
- ISOLATION_READ_COMMITTED :保证一个事物提交后才能被另外一个事务读取。另外一个事务不能读取该事物未提交的数据
- ISOLATION_REPEATABLE_READ :这种事务隔离级别可以防止脏读,不可重复读。但是可能会出现幻象读。它除了保证一个事务不能被另外一个事务读取未提交的数据之外还避免了以下情况产生
- ISOLATION_SERIALIZABLE :完全服从ACID隔离原则,确保不发生脏读、不可重复读、和幻读,但执行效率最低
以上就是本文的全部内容,希望对大家的学习有所帮助,欢迎评论交流。能get到知识点不要忘了关注点赞 ~~~