MySQL-binlog、redolog和undolog的区别

区别:

1、binlog是mysql server层面的,用与数据备份和主从复制,每个执行引擎都有这个文件,比如Myisam和InnoDb

2、redoLog是InnoDb引擎特有的(实现了持久性),用于数据update,先将数据更新在内存,然后写入redolog,在空闲的时候写入磁盘

3、undlog也是InnoDb引擎特有的(实现了原子性),保存着更新前的语句,用于sql语句的回滚,MVCC用到了undolog,当读取的行被其他事务锁定时,可以从undolog找出该行记录之前的数据是什么,从而提供版本信息,保证用户的非一致性读取。

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

两阶段提交:在事务提交前redolog会有一个prepare阶段,这个阶段中先记录好redolog,然后在redolog提交commit之前,会记录binlog,记录好了之后会执行commit操作。

数据库崩溃能否使用undolog来恢复?

不能,因为undolog是循环写,写入磁盘后会将数据擦除。需要使用binlog来进行恢复,binlog是追加写。

相关推荐
XDHCOM3 分钟前
ORA-32484重复列名错误,ORACLE数据库CYCLE子句故障修复与远程处理方案
数据库·oracle
翻斗包菜13 分钟前
PostgreSQL 日常维护完全指南:从基础操作到高级运维
运维·数据库·postgresql
呆瑜nuage21 分钟前
MySQL表约束详解:8大核心约束实战指南
数据库·mysql
liliangcsdn30 分钟前
Agent Memory智能体记忆系统的示例分析
数据库·人工智能·全文检索
那个失眠的夜43 分钟前
Mybatis延迟加载策略
xml·java·数据库·maven·mybatis
Rick199344 分钟前
SQL 执行流程
数据库·sql
M--Y1 小时前
Redis常用数据类型
数据结构·数据库·redis
元宝骑士1 小时前
FIND_IN_SET使用指南:场景、优缺点与MySQL优化策略
后端·mysql
猿小喵1 小时前
MySQL慢查询分析与处理-第二篇
数据库·mysql·性能优化
Y001112362 小时前
MySQL-进阶
开发语言·数据库·sql·mysql