数据库
首页 > 数据库> > MySQL事务实现原理

MySQL事务实现原理

作者:互联网

转自:https://blog.csdn.net/qq_46312987/article/details/123941617

           https://blog.csdn.net/binbigdata/article/details/82938781

什么是事务?

事务是访问和更新数据的程序执行单元,事务中可能含有一个或多个SQL语句,这些语句要么全部执行,要么都不执行

回顾MySQL的逻辑架构与存储引擎

如上图所示,MySQL服务器的逻辑架构从上到下分为三层:

ACID

原子性(Atomicity)

一个事务可能包含多个SQL语句,原子性就是要保证这些SQL语句要么全部执行,要么全不执行

举个例子:

A想要从自己的帐户中转1000块钱到B的帐户里。那个从A开始转帐,到转帐结束的这一个过程,称之为一个事务。在这个事务里,要做如下操作:

1. 从A的帐户中减去1000块钱。如果A的帐户原来有3000块钱,现在就变成2000块钱了。

2. 在B的帐户里加1000块钱。如果B的帐户如果原来有2000块钱,现在则变成3000块钱了。

如果在A的帐户已经减去了1000块钱的时候,忽然发生了意外,比如停电什么的,导致转帐事务意外终止了,而此时B的帐户里还没有增加1000块钱。那么,我们称这个操作失败了,要进行回滚。回滚就是回到事务开始之前的状态,也就是回到A的帐户还没减1000块的状态,B的帐户的原来的状态。此时A的帐户仍然有3000块,B的帐户仍然有2000块。

我们把这种要么一起成功(A帐户成功减少1000,同时B帐户成功增加1000),要么一起失败(A帐户回到原来状态,B帐户也回到原来状态)的操作叫原子性操作。

一致性(Consistency)

事务在系统完整性中实施一致性,这通过保证系统的任何事务最后都处于有效状态来实现。如果事务成功地完成,那么系统中所有变化将正确地应用,系统处于有效状态。如果在事务中出现错误,那么系统中的所有变化将自动地回滚,系统返回到原始状态。因为事务开始时系统处于一致状态,所以现在系统仍然处于一致状态。

隔离性(Isolation)

并发事务之间互相影响的程度,比如一个事务会不会读取到另一个未提交的事务修改的数据。在事务并发操作时,可能出现的问题有:

事务的隔离级别从低到高有:

通常,在工程实践中,为了性能的考虑会对隔离性进行折中。

标签:事务,帐户,提交,块钱,MySQL,原理,1000
来源: https://www.cnblogs.com/pengsay/p/16341508.html