spring有几种事务隔离级别?

啊码 啊码     2022-12-08     416

关键词:

Spring 中的事务隔离级别和数据库中的事务隔离级别稍有不同,以 MySQL 为例,MySQL 的 InnoDB 引擎中的事务隔离级别有 4 种,而 Spring 中却包含了 5 种事务隔离级别。

1.什么是事务隔离级别?

事务隔离级别是对事务 4 大特性中隔离性的具体体现,使用事务隔离级别可以控制并发事务在同时执行时的某种行为。

比如,有两个事务同时操作同一张表,此时有一个事务修改了这张表的数据,但尚未提交事务,那么在另一个事务中,要不要(或者说能不能)看到其他事务尚未提交的数据呢?

这个问题的答案就要看事务的隔离级别了,不同的事务隔离级别,对应的行为模式也是不一样的(有些隔离级别可以看到其他事务尚未提交的数据,有些事务隔离级别看不到其他事务尚未提交的数据),这就是事务隔离级别的作用。

2.Spring 事务隔离级别

Sping 中的事务隔离级别有 5 种,它们分别是:

  1. DEFAULT: Spring 中默认的事务隔离级别 ,以连接的数据库的事务隔离级别为准;
  2. READ_UNCOMMITTED:读未提交,也叫未提交读,该隔离级别的事务可以看到其他事务中未提交的数据。该隔离级别因为可以读取到其他事务中未提交的数据,而未提交的数据可能会发生回滚,因此我们把该级别读取到的数据称之为脏数据,把这个问题称之为脏读;
  3. READ_COMMITTED:读已提交,也叫提交读,该隔离级别的事务能读取到已经提交事务的数据,因此它不会有脏读问题。但由于在事务的执行中可以读取到其他事务提交的结果,所以在不同时间的相同 SQL 查询中,可能会得到不同的结果,这种现象叫做不可重复读;
  4. REPEATABLE_READ:可重复读,它能确保同一事务多次查询的结果一致。但也会有新的问题,比如此级别的事务正在执行时,另一个事务成功的插入了某条数据,但因为它每次查询的结果都是一样的,所以会导致查询不到这条数据,自己重复插入时又失败(因为唯一约束的原因)。明明在事务中查询不到这条信息,但自己就是插入不进去,这就叫幻读 (Phantom Read);
  5. SERIALIZABLE:串行化,最高的事务隔离级别,它会强制事务排序,使之不会发生冲突,从而解决了脏读、不可重复读和幻读问题,但因为执行效率低,所以真正使用的场景并不多。

所以, 相比于 MySQL 的事务隔离级别,Spring 中多了一种 DEFAULT 的事务隔离级别 。

事务隔离级别与问题的对应关系如下:

  • 脏读:一个事务读取到了另一个事务修改的数据之后,后一个事务又进行了回滚操作,从而导致第一个事务读取的数据是错误的。
  • 不可重复读:一个事务两次查询得到的结果不同,因为在两次查询中间,有另一个事务把数据修改了。
  • 幻读:一个事务两次查询中得到的结果集不同,因为在两次查询中另一个事务有新增了一部分数据。

3.设置事务隔离级别

在 Spring 中,事务的隔离级别有 2 种设置方法,一种是在编程式事务中,可以通过以下代码来设置事务隔离级别:

另一种是在声明式事务中设置事务隔离级别,设置方法如下:

总结

Spring 中的事务隔离级别比 MySQL 中的事务隔离级别多了一种,它包含的 5 种隔离级别分别是:

  1. Isolation.DEFAULT:默认的事务隔离级别,以连接的数据库的事务隔离级别为准。
  2. Isolation.READ_UNCOMMITTED:读未提交,可以读取到未提交的事务,存在脏读。
  3. Isolation.READ_COMMITTED:读已提交,只能读取到已经提交的事务,解决了脏读,存在不可重复读。
  4. Isolation.REPEATABLE_READ:可重复读,解决了不可重复读,但存在幻读(MySQL 数据库默认的事务隔离级别)。
  5. Isolation.SERIALIZABLE:串行化,可以解决所有并发问题,但性能太低。

但 需要注意是 Spring 是事务隔离级别是建立在连接的数据库支持事务的基础上的 ,如果 Spring 项目连接的数据库不支持事务(或事务隔离级别),那么即使在 Spring 中设置了事务隔离级别,也是无效的设置。

spring是怎么通过aop实现事物管理的,它支持哪几种事务隔离类型;

Spring支持JDBC规范定义的四种隔离级别,分别是intTRANSACTION_NONE =0;intTRANSACTION_READ_UNCOMMITTED=1;intTRANSACTION_READ_COMMITTED=2;intTRANSACTION_SERIALIZABLE=8;Spring可以有效设定这些事务隔离级别,并可以设定事务传播时的行为。前提是:数据库要支... 查看详情

spring事务隔离级别

Spring事务的隔离级别 1.ISOLATION_DEFAULT:这是一个PlatfromTransactionManager默认的隔离级别,使用数据库默认的事务隔离级别.     另外四个与JDBC的隔离级别相对应 2.ISOLATION_READ_UNCOMMITTED:这是事务最低的隔离级... 查看详情

spring事务的隔离级别

1. ISOLATION_DEFAULT:这是一个PlatfromTransactionManager 默认的隔离级别,使用数据库默认的事务隔离级别. 另外四个与JDBC的隔离级别相对应:2. ISOLATION_READ_UNCOMMITTED:这是事务最低的隔离级别,它允许令外一个事务可以看... 查看详情

spring_事务的几种属性

参考技术Afalse/true是否只读,如果只有查询,设置为true,效率高;增加,删除,修改操作时,设置为falsePropagation.REQUIRED/REQUIRES_NEW/NOT_SUPPORTED/MANDATORY/SUPPORTS/Never/NESTED其中,最常用的是前两个;REQUIRED:两个方法中的事务,进行事务... 查看详情

spring事务类型与隔离级别

参考技术A我是在测试spring事务的时候发现了这种东西,spring的@Transactional注解模型开启的事务类型默认为:Propagation.REQUIRED,隔离级别默认为:Isolation.DEFAULT。所有的事务类型都在Propagation枚举类中。所有隔离级别Isolation枚举类中... 查看详情

Spring Boot 事务隔离级别

】SpringBoot事务隔离级别【英文标题】:SpringBootTransactionIsolationLevel【发布时间】:2020-06-0722:23:15【问题描述】:我有这个项目试图检查事务隔离。我从READ_UNCOMMITTED级别开始,但它不起作用。代码非常简单。主类@SpringBootApplication@... 查看详情

spring事务的传播级别和隔离级别

...播级别1)@Transactional(propagation=Propagation.REQUIRED):默认的spring事务传播级别,使用该级别的特点是,如果上下文中已经存在事务,那么就加入到事务中执行,如果当前上下文中不存在事务,则新建事务执行,所以这个级别通常能... 查看详情

浅析spring事务传播行为和隔离级别

7个传播行为。4个隔离级别。 Spring事务的传播行为和隔离级别[transaction behaviorand isolatedlevel]Spring中事务的定义:Propagation(key属性确定代理应该给哪个方法添加事务行为。这种属性最重要的部份是传播行为。)有下面... 查看详情

spring中五个事务的隔离级别和七种传播行为

Spring在TransactionDefinition接口中定义了五个不同的事务隔离级别DEFAULT:默认的隔离级别,使用数据库默认的事务隔离级别READ_COMMITTED:保证一个事务修改的数据提交后才能被另外一个事务读取。另外一个事务不能读取该事务未提交... 查看详情

spring事务失效

...ava接口中,定义了“四种”的隔离级别枚举:/***【Spring独有】使用后端数据库默认的隔离级别**MySQL默认采用的REPEATABLE_READ隔离级别*Oracle默认采用的READ_COMMITTED隔离级别*/intISOLATION_DEFAULT=-1;/***最低的隔离级别,允许读取尚... 查看详情

spring事务

Spring事务属性的种类:   1)传播行为:定义了被调用方法的事务边界。   2)隔离级别:在操作数据时可能带来3个副作用,分别是脏读、不可重复读、幻读。SQL和Spring都分别提供了几种隔离级别来避免副作用的产生   3... 查看详情

Spring事务性只读和隔离级别

】Spring事务性只读和隔离级别【英文标题】:SpringtransactionalreadOnlyandisolationlevels【发布时间】:2018-08-0207:01:21【问题描述】:我读到了spring/hibernate中的传播和隔离。我有一种特定的方法,我们有0.@Transactional(thedefaultspringannotation)... 查看详情

spring事务传播属性和隔离级别

一、Spring事务传播属性(Propagation):1)REQUIRED(默认属性)如果存在一个事务,则支持当前事务。如果没有事务则开启一个新的事务。 被设置成这个级别时,会为每一个被调用的方法创建一个逻辑事务域。如果前面的方法已... 查看详情

spring事务隔离级别与传播行为

org.springframework.transactionpublicinterfaceTransactionDefinition定义符合Spring的事务属性的接口。基于类似于EJBCMT属性的传播行为定义。‎‎注意,除非启动实际的新事务,否则不会应用隔离级别和超时设置。‎‎仅‎PROPAGATION_REQUIRE... 查看详情

spring事务隔离级别与传播行为

org.springframework.transactionpublicinterfaceTransactionDefinition定义符合Spring的事务属性的接口。基于类似于EJBCMT属性的传播行为定义。‎‎注意,除非启动实际的新事务,否则不会应用隔离级别和超时设置。‎‎仅‎PROPAGATION_REQUIRE... 查看详情

《spring设计思想-事务篇》-数据库隔离级别

0.前言数据库的事务隔离级别是关系型数据库事务的理论基础,本文将从资源互斥的角度从上到下依次进行阐释。1.数据库的事务隔离级别1.1事务的隔离级别,隔离的是什么?在阐述数据库事务的隔离级别时,我们首先... 查看详情

spring事务传播属性和隔离级别

1)REQUIRED(默认属性)如果存在一个事务,则支持当前事务。如果没有事务则开启一个新的事务。 被设置成这个级别时,会为每一个被调用的方法创建一个逻辑事务域。如果前面的方法已经创建了事务,那么后面的方法支持... 查看详情

数据库事务的四大特性以及事务的隔离级别-与-spring事务传播机制&隔离级别

   本篇讲诉数据库中事务的四大特性(ACID),并且将会详细地说明事务的隔离级别。  如果一个数据库声称支持事务的操作,那么该数据库必须要具备以下四个特性:⑴原子性(Atomicity)  原子性是指事务包含的所... 查看详情