事务基于InnoDB引擎,MyISAM不支持事务,这也是Mysql5.6后将InnoDB作为默认数据库的原因之一
隔离级别
SQL 标准的事务隔离级别包括:
读未提交(read uncommitted)、读提交(read committed)、
可重复读(repeatable read)和串行化(serializable )。
读未提交是指,一个事务还没提交时,它做的变更就能被别的事务看到()。
读提交是指,一个事务提交之后,它做的变更才会被其他事务看到。
可重复读是指,一个事务执行过程中看到的数据,总是跟这个事务在启动时看到
的数据是一致的。当然在可重复读隔离级别下,未提交变更对其他事务也是不
可见的。
串行化,顾名思义是对于同一行记录,“写”会加“写锁”,“读”会加“读锁”。当出
现读写锁冲突的时候,后访问的事务必须等前一个事务执行完成,才能继续
执行。
事务的实现(MVCC多版本并发并发控制):
读提交和可重复读都是基于视图(read-view)实现的
读提交:每个SQL语句开始时创建一个视图
可重复读:事务开始时创建一个视图
数据库的MVCC:一条记录上可能存在多个版本(视图)
记录的每次更新都会记录一个回滚操作(图中箭头代表回滚,更新的逆运算),假使图中情况下,事务开始时创建的视图是read-view A,读取值时,并不是直接读到数值,而是通过从read-view C往前回滚。
- read-view C:当前值 —— 4,回滚操作 —— 4-1
- read-view B:当前值 —— 3,回滚操作 —— 3-1
- read-view A:当前值 —— 2,回滚操作 —— 2-1
参考:极客时间 Mysql45讲专栏 作者:林晓斌, 网名"丁奇",腾讯云数据库负责人