Mysql事务隔离级别有哪四种?脏读,幻读,不可重复的含义又是什么?

事务隔离级别是确保数据库并发访问时数据一致性的重要机制。本文详细介绍了SQL标准定义的四种隔离级别:读未提交、读已提交、可重复读和串行化,以及它们如何防止脏读、不可重复读和幻读问题。MySQL的默认隔离级别为可重复读。理解这些概念有助于优化数据库事务处理。
摘要由CSDN通过智能技术生成

概念

事务隔离级别(Isolation)是反映多事务之间不会产生影响,是提交并发访问的处理态度。

如果不考虑事务的隔离级别,会有三个问题:脏读、不可重复读、幻读的情况。

请添加图片描述

脏读:

在多事务之间,一个未提交事务读取到另一个未提交事务修改的数据。

例如A和B同时对数据C进行修改,这时A就可能读取到B还没有提交事务的数据。如果B把事务回滚了,那么A读取的数据就会有问题。这就是脏读。

不可重复读:

一个未提交的事务读取到另一个提交事务修改的数据。

例如A和B同时对数据C进行修改,都开启了数据,假设B对数据进行了修改,并且提交了事务,这时A就可以读取到B修改之后的数据。而A的事务还没有提交,这就是不可重复读。通常针对数据更新(UPDATE)操作。

幻读:

一个未提交事务读取到另一个提交事务添加的数据。

针对数据插(INSERT)操作来说的。假设事务A对某些行的内容作了更改,但是还未提交,此时事务B插入了与事务A更改前的记录相同的记录行,并且在事务A提交之前先提交了,而这时,在事务A中查询,会发现好像刚刚的更改对于某些数据未起作用,但其实是事务B刚插入进来的,让用户感觉很魔幻,感觉出现了幻觉,这就叫幻读。

四种隔离级别

SQL 标准定义了四种隔离级别,MySQL 全都支持。这四种隔离级别分别是:
READ UNCOMMITTED:读未提交,会产生脏读、不可重复读和幻读。
READ COMMITTED:读已提交,会产生不可重复读和幻读。
REPEATABLE READ:可重复读,会产生幻读。(MySQL的默认级别)
SERIALIZABLE:串行化,不会产生脏读、不可重复读和幻读。(单线程执行)
在这里插入图片描述
均是查看资料,学习所得,如有侵权请联系我。

请添加图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值