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