深入理解mysql(六):undo log

一.概论

通过前面的文章,我们已经知道mysql在修改数据的时候,会把数据从磁盘加载到buffer pool中,修改里面的free/flush/lru链表,IO线程会后台刷新数据到磁盘中,同时会把数据记录到redolog中,防止mysql宕机时候数据的丢失,如果一个事物包含多个sql,比如三个增删改sql,前两个sql执行好了,这个时候需要回滚事物,但是缓存中的前两个sql的数据都已经改了,怎么才能进行回滚呢? 这就需要undo log

二.undo log

2.1 undo log简介

undolog回滚日志,记录的东西不是很复杂,其实就是记录你sql执行的逆过程,比如你执行一个insert插入一条新数据,那么undolog日志中就必须记录这个主键和对应的一个delete语句,能把你的insert语句进行回滚;

如你你执行是一个delete语句,那么起码要把你删除的数据记录要下,这样事物回滚的时候,就能把之前删除的数据再次添加进来

如果你执行是update语句,就要把修改之前的旧值记录下来,方便回滚的时候回复原来的数据

如果你执行是select语句,那最好,因为select语句根本不需要记录undolog中,😄😄😄😄

2.2 undolog 的格式

回滚日志包含下面五部分,下图所示

1.日志开始位置

一条日志必须要知道从那里开始,到那里结束

2.主键的各列长度和值

插入一条数据,必然有一个主键,哪怕自己没有设置主见id,mysql也会默认生成一个隐藏的row_id作为主键;这个主键还可以是自己设置的联合主键,比如 "id+name+city",这个时候就需要记录这个主键的各列的长度和值

3.表id

每次对数据库进行操作,肯定要记录是对哪个表进行操作,所以要记录下来

4.日志编号

一个事物有多个sql,就会有多个undolog日志

5.日志类型

常用的有下面几种

  1. TRX_UNDO_INSERT_REC:表示在事务中插入记录时生成的undo日志。
  2. TRX_UNDO_UPDATE_REC:表示在事务中更新记录时生成的undo日志。
  3. TRX_UNDO_DELETE_REC:表示在事务中删除记录时生成的undo日志。

6.结束标志

和开始标志一样,不做赘述

三.总结

undolog还是比较容易理解的,就是把事物中的sql记录下来,后面回滚的时候能进行逆向操作即可

相关推荐
sunfove38 分钟前
光电共封装(CPO):突破算力互连瓶颈的关键架构
人工智能·架构
装不满的克莱因瓶44 分钟前
【2026最新 架构环境安装篇三】Docker安装RabbitMQ4.x详细教程
linux·运维·docker·容器·架构·rabbitmq
李慕婉学姐2 小时前
Springboot旅游景点管理系统2fj40iq6(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
蓝眸少年CY2 小时前
(第八篇)spring cloud之zuul路由网关
后端·spring·spring cloud
Coder_Boy_2 小时前
基于SpringAI的在线考试系统-DDD(领域驱动设计)核心概念及落地架构全总结 (2)
java·人工智能·spring boot·架构·serverless·ddd·服务网格
long3163 小时前
弗洛伊德·沃肖算法 Floyd Warshall Algorithm
java·后端·算法·spring·springboot·图论
Python_Study20253 小时前
TOB机械制造企业获客困境与技术解决方案:从传统模式到数字化营销的架构升级
大数据·人工智能·架构
Loo国昌3 小时前
【LangChain1.0】第一篇:基础认知
后端·python·算法·语言模型·prompt
源代码•宸3 小时前
Golang原理剖析(channel面试与分析)
开发语言·经验分享·后端·面试·golang·select·channel
小程同学>o<3 小时前
嵌入式之ARM体系与架构面试题(一)硬件基础篇
arm开发·笔记·学习·面试·架构