什么是undo log

Undo log的作用
用于事务回滚操作 当事务需要回滚时,需要从undo log中获取数据修改的前映像,以便于将数据恢复到修改前的状态。
提供一致性读 当一个事务需要读取的数据正在被另一个事务修改时,为了避免脏读,需要利用undo log构造出数据块被修改前的一致性的数据块。
用于实例恢复 当实例崩溃重启后,需要通过undo log将未提交的事务回滚,使实例恢复到崩溃前的一致性状态。
undo log详细内容

















KDO Op code: DRP --表示操作类型,DRP=delete row piece。 bdba: 0x01800417 --对应的数据文件和块,转换成二进制,前10位为数据文件号,后22位为块号 ,6 号数据文件,1047号块。 slot: 100(0x64) --行在数据块中的位置,与上面select出来的row number正好对应。



col 1: [ 1] 63 --转换成字符为c。 rci 0x05 -- 指向同一个事务的上一条undo记录。



update、insert、delete操作时,undo中记录的信息不一样。
insert时,只记录了插入数据在数据块中的位置。 update时,记录的是修改字段的前镜像值。 delete时,记录的是整行数据。insert记录的信息最少,update记录的信息居中,delete记录的信息最多。

本文作者:江金林(上海新炬中北团队)
本文来源:“IT那活儿”公众号

文章转载自IT那活儿,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【专家有话说第五期】在不同年龄段,DBA应该怎样规划自己的职业发展?
墨天轮编辑部
1240次阅读
2025-03-13 11:40:53
Oracle RAC ASM 磁盘组满了,无法扩容怎么在线处理?
Lucifer三思而后行
749次阅读
2025-03-17 11:33:53
Oracle+Deepseek+Dify 实现数据库数据实时分析
bicewow
661次阅读
2025-03-06 09:41:49
【ORACLE】ORACLE19C在19.13版本前的一个严重BUG-24761824
DarkAthena
550次阅读
2025-03-04 14:33:31
Oracle避坑指南|同名表导出难题:如何精准排除指定用户下的表?
szrsu
506次阅读
2025-03-05 00:42:34
2月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
444次阅读
2025-03-13 14:38:19
Ogg23ai高手必看-MySQL Innodb Cluster跟oracle的亲密接触
曹海峰
440次阅读
2025-03-04 21:56:13
【ORACLE】char类型和sql优化器发生的“错误”反应
DarkAthena
400次阅读
2025-03-04 23:05:01
什么,oracle 主机用户被删了?原来是虚惊一场!
Lucifer三思而后行
396次阅读
2025-03-03 21:12:09
Oracle 如何修改 db_unique_name?强迫症福音!
Lucifer三思而后行
330次阅读
2025-03-12 21:27:56