数据库系统中的Undo和Redo

news/2024/9/13 22:38:57/ 标签: oracle, 数据库

        在数据库管理系统(DBMS)中,undo 和 redo 是两种用于事务管理和故障恢复的重要机制。它们主要涉及事务的提交、回滚以及系统故障后的数据恢复。

Undo(撤销)

作用:undo 用于撤销未提交事务所做的修改,确保数据库的一致性。

工作原理

  1. 回滚事务:当一个事务在完成之前遇到错误或用户要求回滚时,undo 操作会撤销该事务所做的所有修改,使数据库回到事务开始之前的状态。
  2. 故障恢复:在数据库系统崩溃后,如果系统在恢复过程中发现有未提交的事务,undo 操作会撤销这些未提交事务的修改,确保数据库的一致性。

实现方式:在进行数据修改时,数据库系统会在 undo log(撤销日志)中记录数据修改前的旧值。在需要撤销时,系统可以通过这些日志记录将数据恢复到修改前的状态。

Redo(重做)

作用:redo 用于重做已提交事务的修改,确保数据库的持久性。

工作原理

  1. 事务提交:当一个事务提交后,redo 日志会记录该事务的所有修改操作,确保这些修改能够在系统崩溃后被重新应用。
  2. 故障恢复:在数据库系统崩溃后,如果系统在恢复过程中发现有已提交但未持久化到磁盘的事务,redo 操作会重做这些事务的修改,确保所有已提交事务的修改都持久化。

实现方式:在进行数据修改时,数据库系统会在 redo log(重做日志)中记录数据修改后的新值。在系统恢复时,系统可以通过这些日志记录将所有已提交事务的修改重新应用。

案例说明

假设有一个事务 T1,它对数据库中的某一记录进行修改。

  1. 开始事务 T1:记录初始值到 undo log。
  2. 事务 T1 修改数据:将修改后的值记录到 redo log。
  3. 事务 T1 提交:将 redo log 中的记录持久化,以确保事务的修改被永久保存。

如果系统在 T1 提交前崩溃:恢复时,系统会查看 undo log 并撤销 T1 的所有修改,将数据恢复到事务开始前的状态。

如果系统在 T1 提交后崩溃:恢复时,系统会查看 redo log 并重做 T1 的所有修改,确保事务的修改被永久保存。


http://www.ppmy.cn/news/1475534.html

相关文章

Lab1 论文 MapReduce

目录 🌹资源链接 🍔调试技巧 🦅2 Programming Model 🌼2.1 Example 🌼2.2 Types 🌼2.3 More Examples 🦅3 Implementation(实现) 🌼3.1 ~ 3.3 🌼3.4 ~ 3.6…

36. Adam 算法详解

Adam(Adaptive Moment Estimation)是一种结合动量法和自适应学习率的优化算法,自2014年提出以来,迅速成为深度学习中最流行和常用的优化算法之一。Adam算法的核心思想是利用梯度的一阶动量和二阶动量来动态调整学习率,…

Java的高级特性

类的继承 继承是从已有的类中派生出新的类,新的类能拥有已有类的属性和行为,并且可以拓展新的属性和行为 public class 子类 extends 父类{子类类体 } 优点 代码的复用 提高编码效率 易于维护 使类与类产生关联,是多态的前提 缺点 类缺乏独…

RequestContextHolder多线程获取不到request对象

RequestContextHolder多线程获取不到request对象,调用feign接口时,在Feign中的RequestInterceptor也获取不到HttpServletRequest问题解决方案。 1.RequestContextHolder多线程获取不到request对象 异常信息,报错如下: 2024-07-0…

k8s集群新增节点

目前集群状态 如K8S 集群搭建中规划的集群一样 Masternode01node02IP192.168.100.100192.168.100.101192.168.100.102OSCent OS 7.9Cent OS 7.9Cent OS 7.9 目前打算新增节点node03 Masternode01node02node03IP192.168.100.100192.168.100.101192.168.100.102192.168.100.1…

FPGA设计之跨时钟域(CDC)设计篇(1)----亚稳态到底是什么?

1、什么是亚稳态? 在数字电路中,如果数据传输时不满足触发器FF的建立时间要求Tsu和保持时间要求Th,就可能产生亚稳态(Metastability),此时触发器的输出端(Q端)在有效时钟沿之后比较长的一段时间都会处于不确定的状态(在0和1之间振荡),而不是等于数据输入端(D端)的…

升级springboot3.2集成shiro的问题

由于之前的springcloud相关版本太久,很多新功能无法使用,所以打算抽时间把代码的版本做一下升级。使用最新版的springboot3.2,发现shiro过滤器无效。经检查发现原因: springboot3.x使用的是JDK17,从jdk8以后javax.serv…

【数据结构】单链表 双向链表

目录 链表链表的分类单链表单链表接口的实现内部类头插法尾插法任意位置插入查找是否包含关键字key是否在单链表当中删除第一次出现关键字为key的节点删除所有值为key的节点得到单链表的长度清空链表单链表的优缺点 双向链表双向链表接口的实现内部类头插法尾插法任意位置插入查…

微信小程序 - 本地存储 增加有效期

小程序的本地存储API提供了wx.setStorageSync和wx.setStorage来存储数据,注意的是,小程序的本地存储并没有明确的有效期设置,存储的数据在不超过限制的情况下,会一直保留。 一、小程序本地存储API 小程序的本地存储API提供了设置…

32路串口服务器 应用领域

32路串口服务器在多个领域有着广泛的应用,以下是详细的应用实例: 一、工业自动化 在工业自动化领域,32路串口服务器发挥着举足轻重的作用。传统的工业设备往往采用串口通信方式,而串口服务器能够将这些设备接入网络,…

800 元打造家庭版 SOC 安全运营中心

今天,我们开始一系列新的文章,将从独特而全面的角度探索网络安全世界,结合安全双方:红队和蓝队。 这种方法通常称为“紫队”,集成了进攻和防御技术,以提供对威胁和安全解决方案的全面了解。 在本系列的第一篇文章中,我们将指导您完成以 100 欧元约800元左右的预算创建…

金南瓜科技的SECS/GEM解决方案

1. 高稳定性和可靠性:金南瓜SECS/GEM解决方案已在多家知名半导体工厂中稳定运行,实现了7*24小时无重启无故障超过3年时间 。 2. 符合国际标准:金南瓜的解决方案符合SEMI E4、E5、E30、E37通信协议,确保与国际标准的兼容性&#x…

《RWKV》论文笔记

原文出处 [2305.13048] RWKV: Reinventing RNNs for the Transformer Era (arxiv.org) 原文笔记 What RWKV(RawKuv):Reinventing RNNs for the Transformer Era 本文贡献如下: 提出了 RWKV 网络架构,结合了RNNS 和Transformer 的优点,同…

星环科技推出语料开发工具TCS,重塑语料管理与应用新纪元

5月30-31日,2024向星力未来数据技术峰会期间,星环科技推出一款创新的语料开发工具——星环语料开发工具TCS(Transwarp Corpus Studio),旨在通过全面的语料生命周期管理,极大提升语料开发效率,助…

prompt第三讲-PromptTemplate

文章目录 前提回顾PromptTemplateprompt 模板定义以f-string渲染格式以mustache渲染格式以jinja2渲染格式直接实例化PromptTemplatePromptTemplate核心变量 prompt value生成invokeformat_prompt(不建议使用)format(不建议使用) batchstreamainvoke PromptTemplate核心方法part…

Redis实战—秒杀优化(Redis消息队列)

目录 回顾 基于阻塞队列实现程序异步优化 优化代码 总结 Redis消息队列 初始消息队列 基于List结构模拟消息队列 基于PubSub的消息队列 基于Stream的消息队列 基于Stream的消息队列-消费者组 总结 代码实现 回顾 我们回顾一下前文下单的流程,当用户发起…

python:使用openpyxl模块处理excel

前言 最近在实践excel的处理,在此途中,我彻底抛弃了xlwt xlrd的组合,投入了openpyxl这一模块的怀抱。 并成功实现了excel单元格数据的快速访问、修改、样式保持,以及添加填充色等功能。 至于为什么写这个博客,主要是因…

Interpretability 与 Explainability机器学习

在机器学习的范畴中,“Interpretability”(可解释性)和“Explainability”(可解释性)尽管在含义上有重叠部分,但仍存在一些微妙的差异和重点的不同。 “Interpretability”主要强调模型自身的结构和运作方式…

科普文:微服务技术栈梳理

概叙 如上两图所示,微服务架构下,需要的组件很多,上面中也并未列全。下面将梳理一下国内微服务架构下,用到的技术栈,仅供参考。 科普文:12种常见的软件架构-CSDN博客 没有最好的架构,只有最适…

【Android面试八股文】组件化在项目中有什么意义?

一、没有组件化会出现什么问题? 早期的单一分层模式 问题一:无论分包怎么做,随着项目增大,项目失去层次感,后面接手的人扑街问题二:包名约束太弱,稍有不注意,就会不同业务包直接互相调用,代码高耦合问题三:多人开发在版本管理中,容易出现代码覆盖冲突等问题二、组件…