3张图搞懂mysql事务隔离级别以及MVCC

首先先理清事务,事务隔离级别,事务传播的概念。
事务:一组sql要么都失败,要么都成功。

事务隔离级别:事务与事务之间的可见性。有读未提交,读到别人尚未提交的数据。读已提交只能读取别人已提交的事务。可重复读,只能读取别人已提交的事务,并且这个已提交的事务,它开启的时间要小于当前事务开始的时间。序列化,只能有一个事务在运行。

事务传播:如果有事务了,后面创建事务的行为。比如可以加入前面事务,或者新建,或者直接异常等等。

MVCC:中文名叫多版本并发控制是在可重复读的事务级别上,mysql为了提高并发性而使用的技术。前置知识,mysql每一列的数据都会有3行隐藏列DB_TRX_ID事务id,理解成事务开启的时间戳即可,DB_ROLL_PTR指向undo日志的指针,理解成事务回滚操作即可,DB_ROW_ID当前表没有主键索引mysql会自动创建的主键索引。事务快照表,记录当前正在运行的事务所有事务id集合。

先看实例的前置条件
在这里插入图片描述

读以提交场景

在这里插入图片描述

可重复读场景:
在这里插入图片描述

MVCC只能控制到可重复读,解决不了幻读,幻读只能在序列化级别实现。

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值