回滚日志-undo log
undo log也被称为回滚日志,与redo log(物理日志,记录数据页的修改)不同的是,undo log是一种逻辑日志,用于数据修改的回滚,以此保证事务的原子性。
该日志中记录的是数据修改的相反记录,比如:当删除一条记录,日志中会记录一条对应的新增记录。
这样,在事务回滚时,我们就可以从undo log中反向读取相应的内容,并进行回滚;另外我们也可以根据undo log中的内容读取到一条被修改后数据的原值。
undo log 两大作用:
- 实现事务回滚,保障事务的原子性。事务处理过程中,如果出现了错误或者用户执行了 ROLLBACK 语句,MySQL 可以利用 undo log 中的历史数据将数据恢复到事务开始之前的状态。
- 实现 MVCC(多版本并发控制)关键因素之一。MVCC 是通过 ReadView + undo log 实现的。undo log 为每条记录保存多份历史数据,MySQL 在执行快照读(普通 select 语句)的时候,会根据事务的 Read View 里的信息,顺着 undo log 的版本链找到满足其可见性的记录。
redo log 和 undo log 区别在哪?
这两种日志是属于 InnoDB 存储引擎的日志,它们的区别在于:
- redo log 记录了此次事务「修改后」的数据状态,记录的是更新之后的值,主要用于事务崩溃恢复,保证事务的持久性。
- undo log 记录了此次事务「修改前」的数据状态,记录的是更新之前的值,主要用于事务回滚,保证事务的原子性。