mysql 三大日志
2022/9/15 2:18:54
本文主要是介绍mysql 三大日志,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
undo log
undo log 记录数据被修改前的信息。
作用:防止丢失数据,用于事务失败后的回滚,Innodb 存储引擎的最大特点就是支持事务,如果本次更新失败,那么该事务中的所有的操作都必须回滚到执行前的样子,也就是说当事务失败的时候,也不会对原始数据有影响。
添加时机:在mysql将要更新的数据加载到缓冲区Buffer pool 时,同时往 undo 日志文件中插入一条数据初始状态记录的日志。
更新过程:
- 准备更新一条 SQL 语句
- MySQL(innodb)会先去缓冲池(BufferPool)中去查找这条数据,没找到就会去磁盘中查找,如果查找到就会将这条数据加载到缓冲池(BufferPool)中。
- 在加载到 Buffer Pool 的同时,会将这条数据的原始记录保存到 undo 日志文件中。
- 我们需要执行的 SQL 语句已经被加载到 Buffer Pool 中了,然后开始更新这条语句,更新的操作实际是在Buffer Pool中执行的。
redo log
redo 记录的是数据修改之后的值,不管事务是否提交都会记录下来
这篇关于mysql 三大日志的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-25如何部署MySQL集群资料:新手入门教程
- 2024-12-24MySQL集群部署资料:新手入门教程
- 2024-12-24MySQL集群资料详解:新手入门教程
- 2024-12-24MySQL集群部署入门教程
- 2024-12-24部署MySQL集群学习:新手入门教程
- 2024-12-24部署MySQL集群入门:一步一步搭建指南
- 2024-12-07MySQL读写分离入门:轻松掌握数据库读写分离技术
- 2024-12-07MySQL读写分离入门教程
- 2024-12-07MySQL分库分表入门详解
- 2024-12-07MySQL分库分表入门指南