首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >数据库恢复中撤消阶段的补偿日志记录(CLR)

数据库恢复中撤消阶段的补偿日志记录(CLR)
EN

Stack Overflow用户
提问于 2021-09-10 17:39:54
回答 1查看 153关注 0票数 0

补偿日志的重做信息对应于日志条目的撤消信息,这些信息使得在撤消阶段需要创建日志条目。

在我看来,CLR重做信息与触发它们的日志的撤销信息是一样的。

但是,它们是否应该有重做信息,以便在恢复过程中断时取消已执行的撤消操作?

这里有一个例子:

让T2成为一个更宽松的事务:

<#55,T2,P3,J=J+9,J= J-9,#53>

J=J+9是redo-op,J= J-9是撤销-op.

现在,在重做阶段追加到日志文件的CLR应该是:

<#56,T2,J=J-9,__,#53>

将J=J-9作为CLR中的重做信息,作为原始日志条目的撤销操作。如果恢复中断,日志条目#56将在重做阶段执行。

CLR的目的是确保重新启动恢复过程并再次运行它总是会导致相同的结果。在重做阶段运行J=J-9操作如何确保这一点?

有人能给我解释一下吗?

EN

回答 1

Stack Overflow用户

发布于 2021-09-10 17:44:29

您需要对数据库进行更改。如果事务中止,您可以进行更改并记录如何撤消更改,或者可以记录需要做的事情(重做),并查阅数据库和重做日志,以确定数据库的当前状态。另见http://ariel.its.unimelb.edu.au/~yuan/Ingres/clr.html

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69136053

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档