事务的传播级别是指当一个事务在运行过程中遇到不同的数据库事务时,根据事务的隔离级别和已经发生的情况,将如何传播和影响其他事务。在关系型数据库中,常见的隔离级别包括读未提交、读已提交、可重复读和串行化。不同的事务隔离级别会导致不同的传播行为。
事务的传播级别通常取决于以下两个因素:
- 当前事务的隔离级别:如果当前事务的隔离级别高于或等于所操作数据库的事务级别,那么该事务将继承该数据库的事务级别。
- 当前事务遇到的事务状态:当一个事务遇到其他未完成的事务时,将根据具体情况判断事务的行为。
事务的传播行为分为以下四种情况:
- 一级传播(Level 1):如果当前事务处于一个已提交状态的事务之后,并且当前事务的隔离级别为读已提交或更高,那么当前事务将获得一个已提交状态。
- 二级传播(Level 2):如果当前事务处于一个未提交状态的事务之后,并且当前事务的隔离级别为读已提交或更高,那么当前事务将获得一个未提交状态。此时,该事务将无法看到其他未提交事务的数据。
- 三级传播(Level 3):在可重复读隔离级别下,如果当前事务遇到一个已经提交但未被其他事务读取过的数据,那么当前事务可以再次读取该数据。因此,三级传播级别不会导致级联提交或级联回滚。
- 四级传播(Level 4):串行化隔离级别下,所有并发操作都将被暂停,直到当前事务完成。因此,四级传播级别是最严格的隔离级别,会导致所有其他并发操作被阻塞。
Spring事务定义了7种传播机制:
8) PROPAGATION_REQUIRED:默认的Spring事物传播级别,若当前存在事务,则加入该事务,若不存在事务,则新建一个事务。
9) PAOPAGATION_REQUIRE_NEW:若当前没有事务,则新建一个事务。若当前存在事务,则新建一个事务,新老事务相互独立。外部事务抛出异常回滚不会影响内部事务的正常提交。
10) PROPAGATION_NESTED:如果当前存在事务,则嵌套在当前事务中执行。如果当前没有事务,则新建一个事务,类似于REQUIRE_NEW。
11) PROPAGATION_SUPPORTS:支持当前事务,若当前不存在事务,以非事务的方式执行。
12) PROPAGATION_NOT_SUPPORTED:以非事务的方式执行,若当前存在事务,则把当前事务挂起。
13) PROPAGATION_MANDATORY:强制事务执行,若当前不存在事务,则抛出异常.
14) PROPAGATION_NEVER:以非事务的方式执行,如果当前存在事务,则抛出异常。
Spring事务传播级别一般不需要定义,默认就是PROPAGATION_REQUIRED,除非在嵌套事务的情况下需要重点了解。
需要注意的是,不同的数据库管理系统对事务的隔离级别和传播行为可能有不同的实现和命名方式。因此,具体的情况还需要根据所使用的数据库系统来确定。