ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
mysql的大多数事务型存储引擎实现的都不是简单的行级锁,基于提升并发性能的考虑.他们一般都同时实现了多版本并发控制(MVCC) 不仅是mysql,包括oracle,pgsql其他数据可以也实现了mvcc,但是实现的机制不同,没有统一实现标准 可以认为MVCC是行级锁的一个变种,但是很多情况下避免了加锁操作,因此开销更低.虽然实现机制各有不同,但大都实现了非阻塞的读操作,写操作也只锁定必要的行 MVCC的实现,是通过保存数据在某个时间点的快照来实现的.也就是说,不管需要执行多长时间,每个事务看到的数据都是一致的.根据事务开始时间不同,每个事务对同一张表,同一时刻看到的数据可能是不一样的. 不同的存储引擎的MVCC实现的不同,典型的有乐观并发控制和悲观并发控制 --- innodb的MVCC是通过在每行记录的后面保存两个隐藏的列来实现的.这2个列,一个保存了行的创建时间,一个保存了行的过期时间(或者删除时间).当然存储的并不是实际的时间值,而是系统的版本号.每开始一个新的事务,系统版本号都会自动递增. 事务开始时刻的系统版本号会作为事务的版本号,用来和查询到的每行记录的版本号进行比较.下面看一下REPEATABLE READ隔离级别下,MVCC具体如何操作 ![](https://box.kancloud.cn/a8c267ce6039010d8d3111226ad95887_689x432.png) 保存这2个额外的系统版本号,使大多数读操作都可以不用加锁.这样设计使得读数据操作很简单,性能很好,并且也能保证只会读取到符合标准的行 不足之处是每行记录都需要额外的空间,需要做更多的检查,以及一些额外的维护工作 MVCC只在REPEATABLE READ 和 READ COMMITTED 两个隔离级别下的工作 其他隔离级别都和MVCC不兼容,因为READ UNCOMMITTED总是读取最新的数据行,而不是符合当前事务版本的数据行,而SERIALIZABLE会对所有读取的行都要加锁