一篇文章带你掌握mysql的一致性视图(MVCC)
Posted 大数据真好玩
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一篇文章带你掌握mysql的一致性视图(MVCC)相关的知识,希望对你有一定的参考价值。
回复”资源“获取更多惊喜
提到事务,你肯定会想到ACID(Atomicity、Consistency、Isolation、Durability,即原子性、一致性、隔离性、持久性),我们就来说说其中I,也就是“隔离性”。
当数据库上有多个事务同时执行的时候,就可能出现脏读(dirty read)、不可重复读(non-repeatable read)、幻读(phantom read)的问题,所以下面我们来说说隔离级别。
SQL标准的事务隔离级别包括:读未提交(read uncommitted)、读提交(read committed)、可重复读(repeatable read)、串行化(serializable)。
读未提交是指,一个事务还没提交时,它做的变更就能被别的事务看到。
读提交指,一个事务提交之后,它做的变更才会被其他事务看到。
可重复读指,一个事务执行过程中看到的数据,总是跟这个事务在启动时看到的数据时一致的。当然可重复读隔离级别下,未提交变更对其他事务也是不可见的。
串行化,顾名思义是对于同一行记录,“写”会加“写锁”,“读”会加“读锁”。当出现读写锁冲突的时候,后访问的事务必须等前一个事务执行完成,才能继续执行。
mysql中支持的四种隔离级别
MySQL虽然支持4种隔离级别,但与SQL标准中所规定的各级隔离级别允许发生的问题却有些出入,MySQL在REPEATABLE READ隔离级别下,是可以禁止幻读问题的发生的。
我们可以通过:SET [GLOBAL|SESSION] TRANSACTION ISOLATION LEVEL level;
来设置隔离级别。
其中的level可选值有4个:
Copy以上是关于一篇文章带你掌握mysql的一致性视图(MVCC)的主要内容,如果未能解决你的问题,请参考以下文章
事务四大特性——一致性(Consistency)——MVCC
事务四大特性——一致性(Consistency)——MVCC