Mysql的InnoDB引擎中MVCC在实际操作中有关update的问题

 地之南_816 发布于 2022-11-06 11:04

《高性能mysql》这本书上说有关MVCC中update的说法是:
InnoDB会为每个需要更新的行, 建立一个新的行拷贝, 并且为新的行拷贝, 记录当前的系统版本号。 同时, 也为更新前的旧行, 记录系统的版本号, 作为旧行的删除版本标识。

那么我的问题是:
1.在执行update操作后,原有的记录不是被删除而是在数据库表中与新记录共存?
2.如果不是使用MVCC, 而是普通的update更新操作, 是否会保存原来的旧的记录, 还是在原记录上更新并保存?
求指点!

1 个回答
  • 1.不论怎样都不是真的删除,设置delete标记,记录事务ID。
    2.mvcc是一种多版本机制,不是你用或不用的问题,up时都是针对当前读,只有select才是快照读。

    2022-11-12 01:56 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有