MVCC常问面试题(面试重点)

如果你是路人建议先看一遍参考:MVCC多版本并发控制
看完再看我这个、我提炼是一些面试中用来回答的参考。

知道什么是当前读和快照读吗?

答:简单来说在高并发情况下当前读是获取最新的记录并且其他事务不能修改这个记录、快照读获取的有可能是老的数据。
当前读是加了锁的、加的是一种悲观锁。而快照读是没加锁的。

请你讲下MVCC是什么?

答:全称Multi-Version Concurrency Control、就是一种多并发版本控制器、通俗点就是一种并发控制的方法,一般用于数据库中对数据库的并发访问。Mysql中的innoDB中就是使用这种方法来提高读写事务控制的、他大大提高了读写事务的并发性能,原因是MVCC是一种不采用锁来控制事物的方式,是一种非堵塞、同时还可以解决脏读,幻读,不可重复读等事务隔离问题,但不能解决更新丢失问题。

小结一下
总之MVCC就是一些大牛、不满意读写使用锁去实现读写冲突问题、而提出的解决方案,一般在数据库中会使用MVCC加锁的方式解决读写、和写写冲突的问题。

说一下MVCC的实现原理?

答:MVCC的实现原理是依靠记录中的3个隐含字段、undo log日志、Read View来实现的。

隐含字段

有三种分别是

  1. 记录事务id的DB_TRX_ID、大小为6bt。
  2. 用来记录上一个版本数据记录的回滚指针、大小为7bt。
  3. 隐含的自增ID,作用是在没有设置主键的情况下自动以DB_ROW_ID产生一个簇拥索引、大小为6bt。
undo log日志

分为两种

  1. insert undo log:事务进行插入操作时产生、在事务回滚时需要,提交事务后可以被立即丢弃。
  2. update undo log:进行update、delete时产生的undo log、不仅在回滚事务时需要、在快照读时也需要。所以不能随便删除,只有在快速读或事务回滚不涉及该日志时,对应的日志才会被purge线程统一清除

purge有点像jvm中的gc垃圾回收器
在这里插入图片描述
实际上对MVCC有帮助的是update undo log、undo log实际就是存在rollback中的旧记录链。

Read View(读视图)

read view读视图就是在进行快照读时会产生一个read view视图、在该事务执行的快照读的那一刻,会生成数据库系统当前的一个快照,记录并维护系统当前活跃事务的ID(当每个事务开启时,都会被分配一个ID, 这个ID是递增的,所以最新的事务,ID值越大)。说白了就是用来记录发生快照读那一刻所有的记录,当你下次就算有执行新的事务记录改变了read view没变读出来的数据依然是不变的。

而隔离级别中的RR(可重复读)、和RC(提交读)不同就是差在快照读时
前者创建一个快照和Read View并且下次快照读时使用的还是同一个Read View所以其他事务修改数据对他是不可见的、解决了不可重复读问题。
后者则是每次快照读时都会产生新的快照和Read View、所以就会产生不可重复读问题。

### MySQL MVCC 面试题及答案 #### 什么是多版本并发控制 (MVCC),其主要优点是什么? MVCC 是一种用于数据库管理系统的技术,允许多个事务同时访问同一数据的不同版本而不互相干扰。最大的好处在于读操作不需要加锁,读写之间也不会发生冲突,这大大提高了 MySQL 数据库系统的并发性能[^1]。 #### InnoDB 中如何实现 MVCC 来保证事务的隔离性? InnoDB 使用隐藏列 `DB_TRX_ID` 记录最近更新这条记录的事物 ID 和 `DB_ROLL_PTR` 指向回滚段的位置。每次修改数据时,旧的数据会被保存到 undo 日志中形成一个链表结构。当有新的查询请求到来时,系统会根据当前事物的状态创建 ReadView 并沿着版本链寻找符合条件的第一个版本返回给用户[^5]。 #### 不同隔离级别下 MVCC 表现有何差异? - **读未提交(READ UNCOMMITTED)**: 这种情况下实际上并没有真正利用上 MVCC 特性,因为可以看到其他尚未提交事务所做的更改。 - **读已提交(READ COMMITTED)**: 每次执行 SELECT 查询都会重新计算一个新的 ReadView ,这意味着即使在同一事务内也可能看到不同的结果集[^3]。 - **可重复读(REPEATABLE READ)**: 整个交易期间只会有一个固定的 ReadView 。因此,在同一个事务内的多次相同条件下的 select 操作总是能看到一致的结果集合。 - **串行化(SERIALIZABLE)**: 此模式强制所有的读取都采用共享锁的方式来进行,从而完全避免了幻影读现象的发生。 #### 解析一条 SQL 执行过程中涉及哪些组件以及它们之间的交互流程? 对于每条进入 MySQL Server 的 SQL 请求而言: 1. 客户端通过连接器与服务器建立 TCP/IP 或者 Unix Socket 形式的网络链接; 2. 如果启用了 Query Cache 功能,则在此处检查是否有匹配项可以直接返回; 3. 经过解析器完成词法和语法层面的校验之后生成抽象语法树 AST; 4. 接下来由预处理模块做更深层次的安全性和合法性检测; 5. 优化器依据多种因素评估不同可能路径的成本开销并挑选最优方案作为最终决定; 6. 最终交由执行器按照既定策略调用底层存储引擎 API 获取所需资源直至全部结束为止; 7. 结果逐步反馈至前端应用层面上显示出来的同时也会被缓存起来供后续重用[^4]。 ```sql SELECT * FROM orders WHERE order_date >= '2023-01-01'; ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值