互联网面试宝典

您现在的位置是: 首页 > MySQL

问题详情

MySQL 中锁和 MVCC 是如何实现的?

面试宝典 2023-06-12 Web前端开发工程师 59
MySQL 中锁和 MVCC 都是用来保证并发控制的机制,但它们的实现方式不同。

锁机制:MySQL 中常见的锁有共享锁(S)和排它锁(X)。共享锁允许多个事务同时读取一条记录,而排它锁只允许一个事务修改一条记录。当一个事务要修改一条记录时,它需要先获得该记录的排它锁,而其他事务要读取该记录时需要获得共享锁。锁机制实现简单,但容易造成死锁、锁竞争等问题。

MVCC 机制:MySQL 的 MVCC 特性通过计算事务的可见性来支持并发控制,它通过版本控制来实现。每个事务在对数据进行修改时都会生成一个唯一的版本号,版本号中包含了事务的启动时间和与之关联的 undo 日志的指针等信息。在读取数据时,MVCC 会根据当前事务的启动时间与版本号进行比较,以判断该数据是否可见。若当前事务的启动时间早于数据的版本号,则该数据对当前事务不可见,否则可见。这个机制比较灵活,不易出现死锁、锁竞争等问题。但是它需要更多的空间来存储版本信息,同时也会带来额外的查询开销。