MySQL中的Innodb存储引擎是如何实现事务

Innodb通过Buffer Pool、Redo Log、Log Buffer、Undo Log来实现事务,以一个update语句为例:

1、Innodb在收到一个update语句后,首先会根据条件找到数据所在的页,并将该页缓存到Buffer Pool中

2、执行update语句,修改Buffer Pool中的数据,也就是内存中的数据

3、针对update语句生成一个Redo Log对象,并将Redo Log对象存入到Log Buffer(Log Buffer是一块内存区域)中

4、同时针对update语句生成Undo Log日志,用于事务回滚

5、如果事务提交成功,那么则把Redo Log对象进行持久化,后续还有其它机制将Buffer Pool中所修改的数据页持久化到磁盘中

6、如果事务提交失败,则利用Undo Log 日志进行回滚

查看Buffer Pool的内存大小的SQL命令:

SHOW GLOBAL VARIABLES LIKE '%innodb_buffer_pool_size%';

默认情况下Buffer Pool的内存大小为128MB

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值