在上面几篇日志配置Spring事务的时候都涉及到了事务的传播和隔离性,这里具体深入理解一下。
当多个事务嵌套时,某个事务的propagation事务传播将会直接影响最终的执行效果。
具体propagation的解释如下:
propagation属性 | 说明 |
REQUIRED | 无论当前事务上下文中有没有事务,都会创建一个新的事务。也即逻辑需要在一个事务中运行,如果方法运行时,已处在一个事务中,那么就加入该事务,否则自己创建一个新的事务 |
SUPPORTS | 如果当前事务上下文中有一个事务,那么使用事务上下文中的事务(加入外层的事务,成为外层事务的一部分);如果没有,那么按照无事务的方式执行 |
MANDATORY | 如果当前事务上下文中有一个事务,那么使用事务上下文中的事务;如果没有,那么抛出 IllegalTransactionStatException |
REQUIRES_NEW | 无论当前事务上下文中没有有事务,都会开启一个新的事务。也即逻辑总是会为自己发起一个新的事务,如果方法已运行在一个事务中,则原有事务被挂起,新的事务被创建,直到方法结束,新事务才结束,原先的事务才会恢复执行 |
NOT_SUPPORTED | 无论当前事务上下文中有没有事务,都会按照无事务的方式执行。----不使用事务,如果当前有事务,则挂起事务。-----如果方法在一个事务中被调用,该事务会被挂起,在方法调用结束后,原先的事务便会恢复执行 |
NEVER | 如果当前事务上下文中有一个事务,就会抛出 IllegelTransactionStatException |
NESTED | 在当前事务上下文的事务中增加一个保存点,如果内嵌事务发生回滚,只会回滚内嵌的事务,不会回滚外层事务。如果外层没有事务,则按照REQUIRED方式执行 |
-----------------------------------------------------------------------------------------------------------------------------
事务隔离性
多个事务并发执行可能出现以下问题:
脏读:一个事务读到另一个事务未提交的更新数据。
例如事务1更新了一条记录,然后事务2读取了该条记录,但是然后事务1回滚了它的更新操作,导致事务2读取的记录其实不是数据库中记录的真实值,出现了脏读。
不可重复读:在同一个事务中,多次读取同一数据,返回的结果有所不同。因为后续读取可以读到另一个事务已提交的更新数据。
幻读:一个事务读取到另一个事务已提交的insert数据。
例如事务1读取了数据库中年龄大于30岁的20条记录,然后事务2插入了一条年龄大于30岁的记录,然后事务1再次读取年龄大于30岁的记录,发现变成了21条,以为产生了幻觉。
-----------------------------------------------------------------------------------------------------------------------------
Spring的事务管理提供了5种事务隔离性属性来解决以上问题:
ISOLATION_DEFAULT是采用数据库默认隔离级别。
ISOLATION_READ_UNCOMMITTED: 事务最低的隔离级别,它允许另外一个事务可以看到这个事务未提交的数据。这种隔离会产生脏读,不可重复读和幻读。
ISOLATION_READ_COMMITTED: 保证一个事务修改的数据提交后才能被另外一个事务读取。另外一个事务不能读取该事务未提交的数据。
ISOLATION_REPEATABLE_READ: 这种事务隔离界别可以防止脏读,不可重复读。但是可能出现幻读。它除了保证一个事务不能读取另外一个未提交的数据外,还避免了不可重复读现象。
ISOLATION_SERIALIZABLE: 这是花费最高代价但是最可靠的事务隔离级别。事务被处理为顺序执行。除了防止脏读,不可重复读外,还避免了幻读。
隔离级别 | 脏读 | 不可重复读 | 幻读 |
未授权读 READ_UNCOMMITTED |
可能发生 | 可能发生 | 可能发生 |
授权读 READ_COMMITTED |
不会发生 | 可能发生 | 可能发生 |
可重复读 REPEATABLE_READ |
不会发生 | 不会发生 | 可能发生 |
序列化 SERIALIZABLE |
不会发生 | 不会发生 | 不会发生 |
相关推荐
在Spring事务管理中,ThreadLocal被用来存储当前线程的事务信息,例如事务隔离级别、是否回滚等。这样,Spring可以在事务范围内正确地传播事务,即使在多线程环境下也能保证事务的正确性。 在Spring的`...
### Spring事务的传播特性和事务隔离级别 #### 一、Spring事务的传播特性(Propagation) 在Spring框架中,事务管理不仅提供了ACID属性的支持,还引入了事务的传播特性,这些特性决定了当一个方法调用另一个方法时,...
Spring事务管理的目的是确保数据的一致性和完整性,尤其是在多操作、多资源的环境中。本Demo将深入探讨Spring如何实现事务的管理。 首先,Spring提供了两种主要的事务管理方式:编程式事务管理和声明式事务管理。 ...
### Spring 事务传播特性和事务隔离级别详解 #### 一、Spring 事务传播特性 在进行多层服务架构设计时,事务的管理尤其重要。为了确保数据的一致性,Spring 提供了一种灵活的方式来控制事务的传播行为。下面详细...
`@Transactional`注解用于标记需要进行事务管理的方法,其包含多个属性,如`propagation`定义事务传播行为,`isolation`定义事务隔离级别,`rollbackFor`指定触发回滚的异常类型等。 `jdbcTemplate`的使用通常涉及...
本DEMO主要探讨的是Spring事务的传播行为和隔离级别,这些概念对于理解和优化数据库操作至关重要。让我们深入理解这些概念及其实际应用。 首先,我们来谈谈事务的传播行为。在Spring中,当一个方法被另一个具有事务...
事务的四大特性,即ACID(原子性、一致性、隔离性和持久性),是保证数据完整性的基石。 Spring事务管理分为编程式事务管理和声明式事务管理两种方式。编程式事务管理通过使用PlatformTransactionManager接口的...
### Spring事务的传播特性和隔离级别 #### 一、事务的基本概念 在计算机科学中,事务(transaction)是指一系列操作的集合,这些操作要么全部成功完成,要么全部失败回滚,确保数据的一致性和完整性。事务具备四个...
Spring 框架提供了一套完善的事务管理机制,其中包含了多种事务传播属性和事务隔离级别。这些特性使得在处理数据库操作时,能够更好地控制事务的边界和行为,从而确保数据的一致性和完整性。 首先,我们来看一下...
总之,“spring 事务传播 demo”将展示如何利用Spring的事务传播特性来处理复杂的业务场景,帮助开发者更好地理解和运用这一强大的工具。通过学习和实践这个示例,你将能够掌握在多层方法调用中如何优雅地管理和协调...
注解中的属性包括`propagation`(事务传播行为)、`isolation`(隔离级别)、`readOnly`(只读事务)、`timeout`(超时时间)和`rollbackFor`(触发回滚的异常类型)等。 2. 事务传播行为(Propagation): Spring...
在Spring4中,JdbcTemplate提供了事务管理的功能,使得开发者能够更好地控制数据库操作的原子性、一致性和隔离性,确保数据的完整性。本文将深入探讨Spring4中JdbcTemplate的事务管理以及相关知识点。 首先,理解...
Spring事务管理是Spring框架的核心特性之一,主要用于处理应用程序中的数据一致性问题。...通过理解和使用Spring事务流程图,我们可以更好地设计和优化我们的应用程序,确保在多线程环境下的数据一致性。
Spring事务管理是企业级Java应用中不可或缺的一部分,它确保了数据的一致性和完整性,尤其是在多线程和分布式环境中。本实例将深入探讨Spring事务管理的实现与应用。 首先,Spring事务管理分为编程式事务管理和声明...
事务管理确保了数据库操作的原子性、一致性、隔离性和持久性(ACID属性),这对于任何处理数据的应用程序来说至关重要。本文将深入探讨Spring中的事务管理,包括其基本概念、工作原理以及如何在实际项目中配置和使用...
在本课程中,我们将深入探讨Spring事务传播原理和数据库事务操作的基本概念,这对于有Spring开发经验的人员来说,是进一步深化事务控制理解的关键。我们还将触及分布式事务的初步知识,帮助开发者更好地掌握基于...
总结来说,Spring事务管理失效的原因是多方面的,涵盖从代理模式原理到AOP的实现细节,再到异常处理机制,以及事务传播和隔离级别的配置等多个层面。开发者需要深入理解Spring框架的内部机制,才能在实际开发中有效...
- 注意事务管理的问题,如未开启事务、事务传播属性设置不正确等。 通过以上步骤和知识点,你可以在Spring Boot 1.2.0版本中成功集成并使用Mybatis,实现高效的数据访问。理解并掌握这些内容,将有助于你构建出...
`<tx:attributes>`元素允许你为不同的方法指定不同的事务属性,如传播行为、隔离级别、超时限制和回滚规则等。例如,你可以设置某些方法在事务内部运行(PROPAGATION_REQUIRED),而其他方法则在新事务中运行...