Loading... ## MVCC ### 当前读: 读取的是记录的最新版本,读取时还要保证其他并发事务不能修改当前记录,会对读取的记录进行加锁。对于我们日常的操作,如: * `select…lock in share mode`(共享锁)。 * `select..…for update、update、insert、delete`(排他锁)都是一种当前读。 ### 快照读: 简单的select(不加锁)就是快照读,快照读,读取的是记录数据的可见版本,有可能是历史数据,不加锁,是非阻塞读。 * Read Committed:每次select,都生成一个快照读。 * Repeatable Read:开启事务后第一个select语句才是快照读的地方。 * Serializable:快照读会退化为当前读。 ### MVCC: 全称Multi-Version Concurrency Control,多版本并发控制。指维护一个数据的多个版本,使得读写操作没有冲突,快照读为MySQL实现MVCC提供了一个非阻塞读功能。MVCC的具体实现,还需要依赖于数据库记录中的三个隐式字段、undo log日志、readView。 #### MVCC 实现原理: 有三个隐藏的字段: > undo log回滚日志,在insert、update、delete的时候产生的便于数据回滚的日志。 > 当insert的时候,产生的undo log日志只在回滚时需要,在事务提交后,可被立即删除。 > 而update、delete的时候,产生的undo log日志不仅在回滚时需要,在快照读时也需要,不会立即被删除。 undo log 版本链: undo log日志会记录原来的版本的数据,因为是通过undo log 日志进行回滚的。 如何确定返回哪一个版本 这是由read view决定返回 undo log 中的哪一个版本。 > RC隔离级别下,在事务中每一次执行快照读时生成ReadView。 > RR隔离级别下,在事务中第一次执行快照读时生成ReadView,后续会复用。 > > [https://www.bilibili.com/video/BV1Kr4y1i7ru?p=145&spm\_id\_from=pageDriver&vd\_source=bbc04b831b54029788a178a7c2e9ae20](https://www.bilibili.com/video/BV1Kr4y1i7ru?p=145&spm_id_from=pageDriver&vd_source=bbc04b831b54029788a178a7c2e9ae20) MVCC 靠 隐藏字段 , undo log 版本链 , read view 实现的。 * 原子性-undo log * 持久性-redo log * 一致性-undo log + redo log * 隔离性-锁 + MVCC Last modification:September 21, 2024 © Allow specification reprint Like 如果觉得我的文章对你有用,请随意赞赏