pursue wind pursue wind
首页
Java
Python
数据库
框架
Linux
中间件
前端
计算机基础
DevOps
项目
面试
书
关于
归档
MacOS🤣 (opens new window)
GitHub (opens new window)
首页
Java
Python
数据库
框架
Linux
中间件
前端
计算机基础
DevOps
项目
面试
书
关于
归档
MacOS🤣 (opens new window)
GitHub (opens new window)
  • MySQL

    • 基础篇

    • 索引篇

    • 事务篇

    • 锁篇

    • 日志篇

    • 内存篇

    • 小记

      • 0万里长征第一步(非常重要) —— 如何愉快的阅读本小册
      • 1装作自己是个小白 —— 重新认识MySQL
      • 2MySQL的调控按钮 —— 启动选项和系统变量
      • 3乱码的前世今生 —— 字符集和比较规则
      • 4从一条记录说起—— InnoDB 记录结构
      • 5盛放记录的大盒子 —— InnoDB 数据页结构
      • 6快速查询的秘籍 —— B+ 树索引
      • 7好东西也得先学会怎么用 —— B+ 树索引的使用
      • 8数据的家 —— MySQL 的数据目录
      • 9存放页面的大池子 —— InnoDB 的表空间
      • 10条条大路通罗马 —— 单表访问方法
      • 11两个表的亲密接触 —— 连接的原理
      • 12谁最便宜就选谁 —— MySQL 基于成本的优化
      • 13兵马未动,粮草先行 —— InnoDB 统计数据是如何收集的
      • 14不好看就要多整容 —— MySQL 基于规则的优化(内含关于子查询优化二三事儿)
      • 15查询优化的百科全书 —— Explain 详解(上)
      • 16查询优化的百科全书 —— Explain 详解(下)
      • 17神兵利器 —— optimizer trace 的神器功效
      • 18调节磁盘和CPU的矛盾 —— InnoDB 的 Buffer Pool
      • 19从猫爷被杀说起 —— 事务简介
      • 20说过的话就一定要办到 —— redo 日志(上)
      • 21说过的话就一定要办到 —— redo 日志(下)
      • 22后悔了怎么办 —— undo 日志
        • 事务回滚的需求
        • 具体介绍每一种类型的修改对应的undo日志最小信息。
        • 介绍undo记录存储的位置以及具体方式
          • undo表空间
        • undo日志的真实格式
      • 23工作面试老大难 —— 锁
      • 24写作本书时用到的一些重要的参考资料
    • 其他

  • Redis

  • ElasticSearch

  • MongoDB

  • 数据库
  • MySQL
  • 小记
pursuewind
2020-11-23
目录

22后悔了怎么办 —— undo 日志

# undo 日志

标签: MySQL 是怎样运行的


# 事务回滚的需求

我们说过事务需要保证原子性,也就是事务中的操作要么全部完成,要么什么也不做。但是偏偏有些时候做到一半的时候会出一些情况,比如:

  • 情况一:事务执行过程中可能遇到各种错误,比如服务器本身的错误,操作系统错误,甚至是突然断电导致的错误。

  • 情况二:程序员可以在事务执行过程中手动输入ROLLBACK语句结束当前的事务的执行。

这两种情况都会导致事务执行到一半就结束,但是事务执行过程中可能已经修改了很多东西,为了保证事务的原子性,我们需要把东西改回原先的样子,这个过程就称之为回滚(英文名:rollback),这样就可以造成一个假象:这个事务看起来什么都没做,所以符合原子性要求。

小时候我非常痴迷于象棋,总是想找厉害的大人下棋,赢棋是不可能赢棋的,这辈子都不可能赢棋的,又不想认输,只能偷偷的悔棋才能勉强玩的下去。悔棋就是一种非常典型的回滚操作,比如棋子往前走两步,悔棋对应的操作就是向后走两步;比如棋子往左走一步,悔棋对应的操作就是向右走一步。数据库中的回滚跟悔棋差不多,你插入了一条记录,回滚操作对应的就是把这条记录删除掉;你更新了一条记录,回滚操作对应的就是把该记录的更新为旧值;你删除了一条记录,回滚操作对应的自然就是把该记录再插进去。说的貌似很简单的样子[手动偷笑😏]

# 具体介绍每一种类型的修改对应的undo日志最小信息。

# 介绍undo记录存储的位置以及具体方式

# undo表空间

innodb_undo_tablespaces

innodb_undo_directory

innodb_max_undo_log_size

innodb_undo_log_truncate

innodb_undo_logs

优惠码不好复制,给您单发一下,期盼能有回复🙏🙏

# undo日志的真实格式

Last Updated: 2023/02/16, 12:02:00
21说过的话就一定要办到 —— redo 日志(下)
23工作面试老大难 —— 锁

← 21说过的话就一定要办到 —— redo 日志(下) 23工作面试老大难 —— 锁→

Theme by Vdoing | Copyright © 2019-2023 pursue-wind | 粤ICP备2022093130号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式
  • 飙升榜
  • 新歌榜
  • 云音乐民谣榜
  • 美国Billboard榜
  • UK排行榜周榜
  • 网络DJ