Spring事务隔离与传播机制

五大事务隔离级别

  1. DEFAULT 使用数据库设置的隔离级别 ( 默认 ) ,由 DBA 默认的设置来决定隔离级别 .
  2. READ_UNCOMMITTED 不可提交读,会出现脏读、不可重复读、幻读 ( 隔离级别最低,并发性能高 )
  3. READ_COMMITTED 提交读,会出现不可重复读、幻读问题(锁定正在读取的行)
  4. REPEATABLE_READ可重复读,会出现幻读问题
  5. SERIALIZABLE 串行化读,把整个表锁住

七大事务传播行为

传播行为是针对方法而言的,假如有2个方法,他们对执行的事务要求不同,那么该如何处理这两者之间的事物关系

public void methodA(){
      methodB();
}

public void methodB(){
}
  1. PROPAGATION_REQUIRED
    要求当前方法一定要在事务的环境下执行,如上,执行methodB时,如果在methodA当前环境下已经开启了事务,那么就在当前事务环境下运行,如果当前不存在事务,则新建一个事务
  2. PROPAGATION_SUPPORT
    当前方法支持在事务环境下运行。如果有事务,则在事务下运行,如果没有事务,则在非事务环境下运行。
  3. PROPAGATION_MANDATORY
    是一个比较懒的做法,如果当前环境有事务,则在事务环境下运行,如果当前不存在事务,那么直接抛出异常(脾气真大)。这样的意义在于让方法无法独立运行,必须依赖于外部事务环境,这样如果methodA或者methodB运行存在错误,则会直接rollback,放弃所有修改。
  4. PROPAGATION_REQUIRES_NEW
    是一个很勤快的做法,无论当前是否已经存在事务,他都会自行创建事务。也就是说,如果当前环境不存在事务,则自行创建事务,如果当前已经存在了事务,那么将当前事务挂起,然后再新建自己的事务运行。这样的意义在于,以methodB为例,如果methodB运行时错误,那么只会导致methodB回滚,而不会导致methodA回滚,这里实际上就是把methodA与methodB看成 了一种平级的而非调用的关系
  5. PROPAGATION_NOT_SUPPORTED
    总是在非事务的环境下运行,如果当前环境存在事务,那么将当前事务挂起。
  6. PROPAGATION_NEVER
    不支持在事务的环境下运行,如果当前环境存在事务,那么直接抛出异常。
  7. PROPAGATION_NESTED
    如果 环境存在事务,则以 REQUIRE 的方式运行,否则以嵌入的方式,运行方法。他的意义在于,如果methodA运行methodB,methodB中抛出异常,不会导致methodA回滚,二methodA中抛出异常,会导致整个methodA与methodB都回滚。

参考 https://blog.csdn.net/weixin_39625809/article/details/80707695

发布了40 篇原创文章 · 获赞 6 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/qq_41332728/article/details/103266469
今日推荐