MySql教程

Mysql基础(四)事务

本文主要是介绍Mysql基础(四)事务,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

事务

  • 隔离级别
  • 事务的实现(MVCC多版本并发并发控制):

事务基于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讲专栏 作者:林晓斌, 网名"丁奇",腾讯云数据库负责人

这篇关于Mysql基础(四)事务的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!