MySQL事务是一组SQL语句,它们需要一次性的执行,是不可能中断或者改变的。一旦事务中的任何语句执行失败,整个事务将失败,它将回滚到事务开始前的原始状态。MySQL支持四种隔离级别,它们分别为读未提交(Read uncommitted)、读已提交(Read committed)、可重复读(Repeatable Read)和串行可临(Serializable)。本文将对这四种隔离级别进行详细阐述,并对MySQL如何实现它们进行阐述。
读未提交(Read uncommitted)是MySQL中最低的事务隔离级别。mysql在此隔离级别下主要是不会检测其他连接的更改,所有的新数据都可以直接读取,即使这条数据可能还在执行中,也可以读取出来。这种隔离级别最大的特点就是性能非常高,但是它却也给应用的正确性带来了威胁。
读已提交(Read committed)是MySQL中比较常用的事务隔离级别,它可以有效的防止“脏读”,在这个隔离级别下,MySQL要求客户端必须等待其他连接的修改提交,然后在进行读取操作。MySQL 在该隔离级别下创建的事务,可以避免读取还在被修改的数据的情况发生,直到事务提交(commit)后才能读取。
可重复读(Repeatable Read)是MySQL支持的最高事务隔离级别,它要求在一个事务开始后结束前,任何改变都无法发生,同时手工加了锁定表,避免及时别的连接改变任何数据。该隔离级别相当于既保证了完整又保证了一致性,但是让开发者放弃了取最新数据的机会,及时别的连接更新了数据,但是本连接却没有读取新的数据。
串行可临(Serializable)是MySQL支持的最低事务隔离级别。MySQL在该隔离级别下限制了多个事务的执行访问的序列,使之看起来像是在一个事务内部进行的串行访问,从而防止并发访问可能导致的完整性问题。 MySQL实现四种事务隔离级别,有以下几种方式。
-
通过读写锁使系统能控制到每一行,读取数据时先上锁,在等待更新语句提交时才解锁,这样可以保证可重复读和串行化可临的隔离级别;
-
采用数据版本标记,每行数据被赋予一个版本号,每当数据被搬出去,就会变更版本号,下一次获取信息的时候,就可以比较版本号,从而实现可重复读;
-
采用中间事务快照,将正在执行的事务的变化复制到一张新的表中,在新表里读取数据,实现事务隔离等级;
-
采用行级锁,这种方式能更好地实现隔离级别,同时也不会影响性能,原因是它只在必要时才上锁。
MySQL的事务隔离机制可以保证数据的一致性及安全性,因此在开发中,应当理解四种隔离级别,并在合适的情况下使用适当的事务隔离级别,从而实现最佳的数据读取及系统性能。