Mysql基础(四)事务

事务基于InnoDB引擎,MyISAM不支持事务,这也是Mysql5.6后将InnoDB作为默认数据库的原因之一

隔离级别

SQL 标准的事务隔离级别包括:
	读未提交(read uncommitted)、读提交(read committed)、
	可重复读(repeatable read)和串行化(serializable )。

读未提交是指,一个事务还没提交时,它做的变更就能被别的事务看到()。

读提交是指,一个事务提交之后,它做的变更才会被其他事务看到。

可重复读是指,一个事务执行过程中看到的数据,总是跟这个事务在启动时看到
	的数据是一致的。当然在可重复读隔离级别下,未提交变更对其他事务也是不
	可见的。

串行化,顾名思义是对于同一行记录,“写”会加“写锁”,“读”会加“读锁”。当出
	现读写锁冲突的时候,后访问的事务必须等前一个事务执行完成,才能继续
	执行。

事务的实现(MVCC多版本并发并发控制):

读提交和可重复读都是基于视图(read-view)实现的

读提交:每个SQL语句开始时创建一个视图
可重复读:事务开始时创建一个视图

数据库的MVCC:一条记录上可能存在多个版本(视图)

记录的每次更新都会记录一个回滚操作(图中箭头代表回滚,更新的逆运算),假使图中情况下,事务开始时创建的视图是read-view A,读取值时,并不是直接读到数值,而是通过从read-view C往前回滚。
在这里插入图片描述

  1. read-view C:当前值 —— 4,回滚操作 —— 4-1
  2. read-view B:当前值 —— 3,回滚操作 —— 3-1
  3. read-view A:当前值 —— 2,回滚操作 —— 2-1

参考:极客时间 Mysql45讲专栏 作者:林晓斌, 网名"丁奇",腾讯云数据库负责人

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值