事务隔离级别和Spring支持的隔离级别

一、事务隔离级别

事务的隔离级别有三种:脏读、幻读、不可重复读

1.脏读(也叫读未提交)

一个事务读到另一个事务未提交的内容

有一个很典型的例子,银行取钱问题。

事务A开启了取钱事务,
——> 切换到事务B,事务B开启了转账事务,
——>切换到事务A,账户里有200块钱,事务A取出100块钱,此时账户里余额为100,
——>切换到事务B,事务B查询到账户里余额为100
——>切换到事务A,A遇到某种错误,事务回滚,余额又变回200元,
——>切换到事务B,事务B往账户里存了300块,将账户余额变更为100+300=400元,提交事务
此时,就发生问题了,正确来讲,此时余额应该为200+300=500元

如何解决脏读呢?使用读已提交

2.幻读

当事务不是独立执行时发生的现象:前后多次读取,数据总量不一致

事务A进行读取总量操作
——> 切换到事务B,事务B执行插入数据操作并提交
——>切换到事务A,事务A再次进行读取总量操作
事务A前后两次读取的数据总量不一样,就像发生了幻觉一样

3.不可重复读

在一个事务里面的操作中发现了未被操作的数据:前后多次读取,数据内容不一致

事务A进行读取操作,由于整个事务A比较庞大,执行完事务A需要时间很长,第一次读取时,账户里有100块钱
——> 切换到事务B,事务B向账户里存了100块钱,且提交事务
——>切换到事务A,事务A再次读取账户余额,获取到的余额为200块
按照正确逻辑,事务A前后读取到的数据应该是一样的,但事务A前后读到的数据不一样,不重复了,系统不能读到重复的数据,称为不可重复读。

如何解决不可重复读呢?使用可重复读

二、Spring支持的隔离级别

事务的隔离级别有五种:默认、读未提交、读已提交、可重复读、串行化

1.默认(DEFAULT)

使用数据库本身使用的隔离级别
ORACLE(读已提交) MySQL(可重复读)

2.读未提交(READ_UNCOMITTED)

读未提交可能会产生:脏读、幻读、不可重复读的问题

3.读已提交(READ_COMMITED)

读已提交指的是:一个事务在进行读取操作时,不读取其它事务未提交的内容,只读取已提交的内容。这样就解决了脏读所产生的问题。

读已提交可能会产生:幻读、不可重复读的问题

4.可重复读(REPEATABLE_READ)

可重复读指的是:一个A事务在进行读取操作时,不允许其它事务来修改A事务所读取的对象,这样就解决了不可重复读和脏读所产生的问题。

可重复读可能会产生:幻读的问题

5.串行化(SERLALIZABLE)

串行化,最高的事务隔离级别,不管多少事务,挨个运行完一个事务的所有子事务之后才可以执行另外一个事务里面的所有子事务,这样就解决了脏读、不可重复读和幻读的问题。

参考文章:
https://blog.csdn.net/qq_33591903/article/details/81672260
https://blog.csdn.net/qq_38526573/article/details/87898730

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
事务隔离级别是指多个事务并发执行时,一个事务对其他事务的可见性和影响程度的控制。Spring框架支持四个事务隔离级别: 1. 未提交读(READ UNCOMMITTED):最低级别,一个事务可以读取未提交的数据,会导致脏读,不可重复读和幻读问题的出现。 2. 提交读(READ COMMITTED):一个事务只能读取已提交的数据,可以避免脏读问题,但可能导致不可重复读和幻读问题。 3. 可重复读(REPEATABLE READ):在一个事务中多次读取同一数据时,结果保持一致,避免了不可重复读问题。但仍然可能存在幻读问题。 4. 串行化(SERIALIZABLE):最高级别,通过确保事务串行执行来避免脏读、不可重复读和幻读问题。但会降低并发性能。 传播机制是指在调用多个事务方法时,如何处理事务传播。Spring框架提供七种传播行为: 1. REQUIRED:如果当前没有事务,就创建一个新事务;如果已存在事务,则加入该事务。 2. SUPPORTS:支持当前事务,如果当前没有事务,就以非事务方法执行。 3. MANDATORY:强制要求存在当前事务,如果没有事务就抛出异常。 4. REQUIRES_NEW:创建一个新事务,并暂停当前事务(如果有)。 5. NOT_SUPPORTED:以非事务方式执行操作,如果当前存在事务,则将其挂起。 6. NEVER:以非事务方式执行操作,如果当前存在事务,则抛出异常。 7. NESTED:在当前事务的控制下执行一个嵌套事务,如果不存在当前事务,则创建一个新事务。嵌套事务可以独立提交或回滚,但在外部事务提交时才会生效。 通过选择合适的事务隔离级别和传播机制,可以确保事务的数据一致性、安全性和性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值