当前位置: 首页 > backend >正文

说下对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一致的可见外,其余不可见。

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

http://www.xdnf.cn/news/15485.html

相关文章:

  • DNS的含义以及例子
  • 传输协议和消息队列
  • Claude 背后金主亚马逊亲自下场,重磅发布 AI 编程工具 Kiro 现已开启免费试用
  • 面向医疗AI场景的H20显卡算力组网方案
  • 正则表达式使用示例
  • C++20 协程参考手册详解 - 源自 cppreference.com
  • 暑假Python基础整理 --异常处理及程序调试
  • 从 0 到 1 掌握 自研企业级分布式 ID 发号器
  • 《C++模板高阶机制解析:非类型参数、特化设计与分离编译实践》
  • 【GEOS-Chem模拟教程第一期上】气溶胶专用/碳气体/全化学模拟
  • x86版的ubuntu上使用qemu运行arm版ubuntu
  • 学习软件测试的第十六天
  • HOOPS Communicator 2025.5.0版本更新速览:性能、测量与UI全面优化
  • 将 Vue 3 + Vite + TS 项目打包为 .exe 文件
  • Kubernetes 架构原理与集群环境部署
  • Mybatis05-动态sql
  • Java实现word、pdf转html保留格式
  • HTTP性能优化实战技术
  • 【电脑】显卡(GPU)的基础知识
  • 暑期算法训练.1
  • 【解决】联想电脑亮度调节
  • 行为模式-状态模式
  • 前端打包自动压缩为zip--archiver
  • MongoDB数据问题说明
  • 大模型在1型糖尿病肾病V期预测及治疗方案制定中的应用研究
  • 《大数据技术原理与应用》实验报告五 熟悉 Hive 的基本操作
  • 用uniapp开发鸿蒙应用(暂停更新-根据项目更新,现在项目未开始)
  • LangChain智能体开发实战:从零构建企业级AI助手
  • 17、鸿蒙Harmony Next开发:状态管理(组件拥有的状态和应用拥有的状态)
  • 3种添加视频水印的加密方式,守护视频安全!