说下对mysql MVCC的理解

我们知道,mysql innodb存储引擎关于事务的默认隔离级别是RR,亦即可重复读。

而MVCC则是RR能够实现可重复读的保证,同时也是RC实现读已提交的保证。

我们先看下MVCC的原英与翻译:multi version concurrent control 多版本并发控制。

我就这个翻译来说道MVCC。它这里的多版本是啥意思?

首先,实现MVCC离不开:undoLog与readView。

undoLog我们应该都知道,存放的是事务更新日志记录,以备事务失败的回滚。

然后我们要知道,mysql每行记录,都有隐藏的db_trx_id(事务id),db_roll_point(回滚到undoLog的id),如果该行没主键则还会有个隐藏主键字段。

readView作为读视图,存放查询那一刻读视图快照,与行记录的trx_id做比较,小于readView的trx_id则记录可见,大于等于readView的trx_id的除了与readView的creator_trx_id一致的可见外,其余不可见。

依赖这两点,可以做到在并发读写事务的时候,既保证数据的安全性,又保证一定的性能。配合锁更可以保证可重复读的同时避免大部份幻读

相关推荐
数据知道7 小时前
PostgreSQL 性能优化:连接数过多的原因分析与连接池方案
数据库·postgresql·性能优化
怣507 小时前
MySQL子查询实战指南:数据操作(增删改查)与通用表达式
数据库·chrome·mysql
范纹杉想快点毕业7 小时前
从单片机基础到程序框架:构建嵌入式系统的完整路径
数据库·mongodb
数据知道7 小时前
PostgreSQL性能优化:如何定期清理无用索引以释放磁盘空间(索引膨胀监控)
数据库·postgresql·性能优化
喵叔哟7 小时前
67.【.NET8 实战--孢子记账--从单体到微服务--转向微服务】--新增功能--分摊功能总体设计与业务流程
数据库·微服务·架构
tryCbest7 小时前
Oracle查看存储过程
数据库·oracle
咩咩不吃草8 小时前
【MySQL】表和列、增删改查语句及数据类型约束详解
数据库·mysql·语法
不懒不懒8 小时前
【MySQL 实战:从零搭建规范用户表(含完整 SQL 与避坑指南)】
数据库
ID_180079054738 小时前
Python结合淘宝关键词API进行商品价格监控与预警
服务器·数据库·python
数据知道8 小时前
PostgreSQL 故障排查:万字详解如何找出数据库中的死锁
数据库·postgresql