当前位置: 首页 > news >正文

数据库是怎么做到事务回滚的呢?

在这里插入图片描述
数据库实现事务回滚的原理涉及到数据库管理系统(DBMS)如何维护事务的一致性和持久性。

基本原理:

  • ACID属性:事务的原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability)是数据库管理系统确保数据完整性和一致性的基本特性。在这些属性中,原子性和持久性是与事务回滚密切相关的。

  • 日志记录:数据库管理系统通过事务日志(Transaction Log)来记录所有事务的操作,包括事务开始、数据修改操作以及事务提交或回滚等信息。事务日志记录了事务的所有操作,在事务提交之前,将修改操作记录在日志中,以便在事务回滚时进行恢复。

  • Undo日志:当事务执行修改操作时,数据库会在事务日志中记录相应的Undo日志,用于在事务回滚时撤销事务所做的修改。Undo日志记录了事务对数据的修改操作,以及恢复这些修改所需的信息,包括修改前的数据值等。

  • 回滚操作:当事务发生错误或者用户显式地执行回滚操作时,数据库管理系统会根据事务日志中的Undo日志信息,逆向执行相应的撤销操作,将事务所做的修改全部撤销,恢复数据库到事务开始之前的状态。这样可以保证事务的原子性,即要么全部执行成功,要么全部回滚。

  • 持久化存储:数据库管理系统通常将事务日志和Undo日志等信息存储在持久化存储介质(如硬盘)上,以确保即使系统发生故障或者断电等情况,日志信息也不会丢失,可以通过回放日志来恢复数据并保证事务的持久性。

数据库的日志 undo log,redo log,bin log

Undo Log(回滚日志):
作用: 记录事务对数据库进行的修改操作的“逆操作”,即撤销操作,用于事务回滚或数据库系统崩溃恢复。
特点: 通常是在数据页上记录旧值,用于在事务回滚或系统崩溃恢复时,将数据恢复到事务开始之前的状态。
应用场景: 用于支持数据库的事务性操作,保证事务的原子性和一致性。

Redo Log(重做日志):
作用: 记录事务对数据库进行的修改操作的“正向操作”,即重做操作,用于在数据库系统崩溃后恢复数据到事务提交之后的状态。
特点: 通常是在日志文件中记录修改操作的“影子拷贝”,用于在系统崩溃后重新执行事务提交之前的修改操作,以确保事务的持久性。
应用场景: 用于数据库系统的崩溃恢复和恢复到最新的一致状态,以保证数据的持久性。

Binlog(二进制日志):
作用: 记录数据库中所有的修改操作,包括数据修改、DDL语句、数据导入导出等,用于数据备份、主从复制和数据恢复等。
特点: 通常是以二进制格式记录数据库的修改操作,可以通过日志解析工具将其解析为SQL语句或者进行数据恢复操作。
应用场景: 用于数据库的备份和恢复、主从复制、数据同步等场景,可以保证数据的一致性和可用性。

Undo Log记录了事务的“逆操作”,Redo Log记录了事务的“正向操作”,而Binlog记录了数据库的所有修改操作,它们分别用于支持事务的原子性和一致性、数据库系统的崩溃恢复以及数据库的备份和恢复等功能。

http://www.lryc.cn/news/326918.html

相关文章:

  • 海思 Hi3519DV500 简介
  • 盘点全球十大FPGA制造商
  • 【MySQL】14. 全文索引(选学)
  • C++实现FFmpeg音视频实时拉流并播放
  • 国内ip切换app,让切换ip变得简单
  • 阿里云倚天服务器是什么?倚天服务器c8y、g8y和r8y详细介绍
  • ip地址开发场景问题
  • 【功能实现】新年贺卡(蓝桥)
  • 【Redis教程0x08】详解Redis过期删除策略内存淘汰策略
  • 鸿蒙开发 TypeScript 基础语法
  • uniapp 未配置appkey或配置错误的解决
  • 【Android】【Bluetooth Stack】蓝牙电话协议之拨打电话分析(超详细)
  • 记录关于智能家居的路程的一个bug___Segmentation fault(段错误)
  • 由浅到深认识Java语言(39):网络编程
  • PCL 彩色点云RGB转灰度并显示
  • RHEL9部署Docker环境
  • Vue3.0云里雾里
  • idea类已经存在却报错
  • MySQL---视图
  • 策略路由-IP-Link-路由协议简介
  • 数位五五(Java)
  • 蓝桥杯G431RBT6——定时器中使用led冲突以及led与lcd冲突等一系列问题
  • 物联网(IoT)常用的通信协议
  • 关于C/C++,Linux/MacOS/Windows 平台虚拟内存分配
  • 如何在服务器上传/下载文件
  • C++ 之多态虚函数原理及应用
  • 亮数据——让你的IP走出去,让价值返回来
  • spring boot-引入Redis并封装redistemplate操作工具类
  • android 11 SystemUI 状态栏打开之后的界面层级关系说明之一
  • C#___锁(lock)