InnoDB 的一次更新事务是怎么实现的?

大体流程:

在这里插入图片描述


步骤:

1.加载数据到缓存中(Buffer Pool):

在进行数据更新时,InnoDB首先会在缓冲池(Buffer Pool)中查找该记录是否已经在内存中。如果记录不在内存中,会将需要更新的数据从磁盘文件加载到内存的缓冲池(Buffer Pool)中。
缓冲池是InnoDB存储引擎提供的缓存,用于加速数据的读取和修改操作。数据加载到缓冲池后,后续的操作都在缓冲池中进行。

2.写入Undo Log:

在更新数据之前,InnoDB会将原始数据的副本写入Undo Log(回滚日志)。
Undo Log是用于事务回滚和并发控制的重要组件,是用来保证事务原子性和一致性的一种机制。它记录了事务开始前的数据状态,以便在需要回滚时进行恢复。

3.更新内存数据:

接下来,InnoDB会在缓冲池中更新数据。
这意味着,当执行update语句时,InnoDB会先更新已经读取到Buffer Pool中的数据,修改操作会直接在内存中进行,而不是立即写入磁盘。
此时,缓冲池中的数据被标记为"脏页",表示与磁盘上的数据不一致。

4.写入Redo Log:

为了保证事务的持久性,InnoDB在Buffer Pool中记录修改操作的同时,InnoDB会先将更新操作写入Redo Log(重做日志)。
Redo Log是一种物理日志,记录了事务对数据库的修改操作。通过Redo Log,即使系统发生故障,也可以通过重做日志来恢复事务修改后的状态。

5.提交事务:

当事务完成所有的更新操作后,事务被提交。在提交事务时,InnoDB会将事务标记为"准备提交"状态。
此时,事务的修改操作仍然在缓冲池中,尚未写入磁盘。

6.写入BinLog:

在事务提交之后,InnoDB会将事务的修改操作写入BinLog(归档日志)。
BinLog是MySQL的二进制日志,用于记录数据库的所有修改操作。在Binlog中记录的信息包括:事务开始的时间、数据库名、表名、事务ID、SQL语句等。它可以用于数据恢复、主从复制、数据分析和同步等场景。

7.刷新脏页到磁盘:

最后,在提交过程完成后,InnoDB会将缓冲池(Buffer Pool)中的脏页刷新到物理磁盘上的数据文件中。
这个过程称为"刷脏"。通过刷脏操作,将缓冲池中的修改操作同步到磁盘,确保数据的持久性。
然而,这个写入过程并非立即执行,而是由后台线程异步执行的,因此可能会有一定的延迟。总而言之,MySQL会在适当的时机选择将数据写入磁盘以进行持久化。

总结:

先从磁盘中加载数据到Buffer Pool(缓存冲) -> 写入Undo log(重做日志)->更新缓存中的数据(对应的数据页被成为脏页)->写Redo log(重做日志)->提交事务->刷脏(将缓存中的数据刷新到磁盘文件中)
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: InnoDB和MyISAM是MySQL数据库中常见的两种存储引擎,它们在很多方面都有很大的区别,下面是它们的主要区别: 1. 锁定机制不同:InnoDB采用行级锁定,而MyISAM采用表级锁定,因此在并发操作时,InnoDB的性能更好。 2. 外键支持不同:InnoDB支持外键,而MyISAM不支持,这使得InnoDB更适合于要求数据完整性的应用程序。 3. 数据缓存方式不同:InnoDB通过缓存池的方式缓存数据,而MyISAM则使用操作系统的文件缓存。 4. 全文索引支持不同:MyISAM支持全文索引,而InnoDB不支持,这也是一些应用程序选择MyISAM的原因。 5. 事务支持不同:InnoDB支持事务,而MyISAM不支持,这使得InnoDB更适合于需要事务支持的应用程序。 总的来说,如果应用程序需要高并发、数据完整性、事务支持等特性,那么InnoDB是更好的选择;如果应用程序需要全文索引等特性,则可以选择MyISAM。 ### 回答2: InnoDB和MyISAM是MySQL数据库中两种常见的存储引擎。它们之间有一些重要的区别。 首先,数据的存储方式不同。InnoDB使用聚簇索引,数据按照主键的顺序存储在磁盘上,这样可以提高查询性能。而MyISAM使用堆表的方式,数据存储在独立的数据文件中,除了主键索引外,还有一个额外的数据文件用于存储非聚簇索引。 其次,事务支持的程度不同。InnoDB支持事务,具有事务的原子性、一致性、隔离性和持久性。这意味着可以在事务中执行多个SQL语句,若发生错误,则可以回滚到事务开始的状态。而MyISAM不支持事务,每个SQL语句都会立即执行,无法回滚。 此外,对并发操作的支持也有差异。InnoDB使用行级锁定,可以实现更好的并发性能,多个事务可以同时读取和写入不同的行。而MyISAM使用表级锁定,若有一个事务正在操作表,则其他事务必须等待该事务完成后才能继续操作表,这会降低并发性能。 另外,数据的完整性约束也不同。InnoDB支持外键约束,可以维护数据之间的一致性,并可以通过级联操作来更新关联表的数据。而MyISAM不支持外键约束,需要应用程序自己来保证数据的完整性。 最后,恢复和备份的能力也有区别。InnoDB支持崩溃恢复,在数据库意外关闭后可以通过日志文件来回滚到最后一次提交的状态。同时也支持在线备份,可以在数据写入时进行备份。而MyISAM不支持崩溃恢复,恢复数据时需要从头开始进行恢复,同时也无法进行在线备份。 总结来说,InnoDB适用于要求数据的一致性、可靠性和高并发性能的应用,而MyISAM适用于对于并发性要求不高、查询较多的应用。选择合适的存储引擎应根据具体的应用需求进行评估。 ### 回答3: InnoDB和MyISAM是MySQL数据库中两种常用的存储引擎,它们具有以下几个主要区别。 1. 事务处理能力:InnoDB支持事务处理,可以实现ACID(原子性、一致性、隔离性和持久性)特性,保证了数据的完整性和一致性。而MyISAM不支持事务处理,无法提供同样的保障。 2. 并发性能:InnoDB采用行级锁定,可以对不同的数据行进行独立锁定,从而提供更好的并发性能。而MyISAM则采用表级锁定,当对同一张表进行并发查询或更新时,会导致其他查询或更新被阻塞,降低了并发性能。 3. 数据缓存和索引:InnoDB通过使用缓冲池(buffer pool)将数据和索引存储在内存中,可以提供更快的读取速度和更高的缓存效率。而MyISAM则需要通过文件系统缓存来读取数据和索引,相对来说速度较慢。 4. 效率和性能:对于大量读取操作的场景,MyISAM比InnoDB效率更高,因为它不需要处理事务和行级锁定的开销。而对于大量写入操作的场景,InnoDB的效率更高,因为它可以保证数据的一致性和完整性。 5. 数据备份和恢复:InnoDB支持热备份,可以在不停机的情况下进行数据备份和恢复。而MyISAM只支持停机备份,需要暂停数据库的运行才能进行备份和恢复操作。 综上所述,InnoDB适用于需要事务支持和高并发性能的场景,对数据的完整性和一致性要求较高。而MyISAM适用于大量读取操作的场景,对数据的一致性要求较低,且需要进行频繁的备份和恢复操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值