MYSQL三个日志

  • undo log(回滚日志):是 Innodb 存储引擎层生成的日志,实现了事务中的原子性,主要用于事务回滚和 MVCC

  • redo log(重做日志):是 Innodb 存储引擎层生成的日志,实现了事务中的持久性,主要用于掉电等故障恢复

  • binlog(归档日志):是 Server 层生成的日志,主要用于数据备份和主从复制

为什么需要 undo log?

当你执行 "增删改" sql语句时,不需要手动的begin和commit事务,MYSQL会 隐式 的开启事务来执行 "增删改",执行成功结束后,会自动提交事务。(autocommit,默认为true)

undo log(回滚日志),它保证了事务的 ACID 特性 (opens new window)中的原子性(Atomicity)

在进行增删改时,会把一些内容记录到undo log里,比如:

  • 执行增语句时,会将 键值 存储到undo log中,回滚就根据主键值删掉记录就好了。

  • 执行删语句时,会将 内容 保存到undo log中,回滚就将内容添加回去就好了。

  • 执行改语句时,会将 旧值 保存到undo log中,回滚就把记录更新为旧值就好了。

一条记录的每一次更新操作产生的 undo log 格式都有一个 roll_pointer 指针和一个 trx_id 事务id:

  • 通过 trx_id 可以知道该记录是被哪个事务修改的;

  • 通过 roll_pointer 指针可以将这些 undo log 串成一个链表,这个链表就被称为版本链;

另外,undo log 还有一个作用,通过 ReadView + undo log 实现 MVCC(多版本并发控制)

对于 读已提交 和 可重复读 隔离级别。对于普通的select的语句是通过MVCC来实现,它们的区别在于创建 ReadView 的时机不同:

  • 读已提交:每个select都会生成一个ReadView,当一个事务执行过程中,另外一个事务在第一个事务过程中提交了,然后第一个事务又执行一个select语句,这时会生成一个ReadView

  • 可重复读:事务开启时,第一个select语句创建一个ReadView,这个事务的操作自始自终都用的这个ReadView。

undo log 两大作用:

  • 实现事务回滚,保障事务的原子性

  • 实现 MVCC(多版本并发控制)关键因素之一

相关推荐

  1. MYSQL

    2024-05-04 06:34:06       34 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-04 06:34:06       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-04 06:34:06       106 阅读
  3. 在Django里面运行非项目文件

    2024-05-04 06:34:06       87 阅读
  4. Python语言-面向对象

    2024-05-04 06:34:06       96 阅读

热门阅读

  1. Python高级编程

    2024-05-04 06:34:06       30 阅读
  2. IP协议的TTL解析(定义、执行、用途)

    2024-05-04 06:34:06       27 阅读
  3. js请求封装ajax、统一响应

    2024-05-04 06:34:06       33 阅读
  4. mac 安装anaconda

    2024-05-04 06:34:06       29 阅读
  5. 嵌入式物联网系统软硬件基础知识大全(2)

    2024-05-04 06:34:06       33 阅读
  6. 【004_音频开发_基础篇_ALSA插件使用】

    2024-05-04 06:34:06       36 阅读
  7. 什么是gcc-arm-linux-gnueabihf?

    2024-05-04 06:34:06       31 阅读
  8. 39 死锁

    39 死锁

    2024-05-04 06:34:06      37 阅读