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

mysql中的MVCC

一.MVCC是什么?

  mvcc多版本并发控制,是mysql中innodb存储引擎实现高并发的重要机制,其核心思想是通过保留数据的多个版本,避免读写阻塞,从而提高数据库的吞吐量。避免了频繁加锁、减少资源竞争,提高并发性能。

二.MVCC的实现原理

  • 基于undolog版本链和readView一致性视图实现。
  • undolog中每条数据都有两个隐藏字段trx_id(当前版本对应的事务id)、roll_point(回滚指针,指向当前版本的上一个版本)
  • readView:
    • m_ids:当前存活的事务id
    • creator_trx_id:当前事务id(创建该readView的事务id)
    • up_limit_id:m_ids中最小的事务id
    • low_limit_id:即将要分配的事务id
  • 可见性判断:
if(trx_id < up_limit_id) {说明该版本对应的事务已经提交了,当前事务可见(可以读取)
}
else if (trx_id == creator_trx_id) {说明该版本是由当前事务自己创建的,可见
}
else if (trx_id >= low_limit_id) {说明该版本对应的事务,是一个未来的事务,当前事务不可见(不可以读取)
}
else {// 介于 up_limit_id 和 low_limit_id 之间if (trx_id 在活跃事务列表 m_ids 中) {// 事务未提交,不可见} else {// 事务已提交,可见}
}

三、读已提交你和可重复读隔离级别下readView的区别

  • 读已提交:同一个事务中,每次查询都会创建一个新的readView
  • 可重复读:同一个事务中,只有第1次查询才会生成readView,后续的查询都使用相同的readView。
http://www.xdnf.cn/news/9093.html

相关文章:

  • PH热榜 | 2025-05-24
  • DRF的使用
  • 【前端】【React】React性能优化系统总结
  • DAY07:Vue Router深度解析与多页面博客系统实战
  • 微信小程序的软件测试用例编写指南及示例
  • kafka SASL/PLAIN 认证及 ACL 权限控制
  • Mysql之用户管理
  • [25-cv-05718]BSF律所代理潮流品牌KAWS公仔(商标+版权)
  • 分布式项目保证消息幂等性的常见策略
  • 并发编程艺术--AQS底层源码解析(三)
  • 华为OD机试真题——构成正方形的数量(2025B卷:100分)Java/python/JavaScript/C++/C/GO六种最佳实现
  • P2340 [USACO03FALL] Cow Exhibition G
  • 时序模型上——ARIMA/
  • 云蝠 Voice Agent:开启大模型时代语音交互新纪元
  • AAOS系列之(四) ---APP端如何获取CarService中的各个服务代理
  • day8补充(中断驱动和队列缓冲实现高效数据处理)
  • day020-sed和find
  • 【C++高阶一】二叉搜索树
  • Speech Synthesis/Text to Speech(TTS)
  • 写给这个阶段自我的一封信
  • Solr搜索:比传统数据库强在哪?
  • 【Ai】使用Ultralytics yolo做图片检测+使用roboflow做数据标注
  • 机器学习与深度学习5:pytorch前馈神经网络FNN实现手写数字识别
  • Halcon仿射变换---个人笔记
  • PySide6 GUI 学习笔记——常用类及控件使用方法(光标类图标QCursor)
  • 918. 环形子数组的最大和
  • 消费电子卷入“技术军备竞赛”
  • shell脚本基础
  • 记忆上传与自我同一性的哲学-技术综合分析
  • AI日报 - 2025年05月26日