mysql update 语句执行链路

mysql innoDB执行update完整执行链路。
1、当你执行一条update语句时。通过连接器,优先查询缓存。因为是更新操作,所以又分析器进行语法此法分析。分析通过以后,进行优化执行计划的生成。索引的选择。然后将结果交个执行器。调用InnoDB引擎。
2、InnoDB引擎的BufferPool在磁盘中加载缓存数据,一般加载一个page,一个mysql page一般为16k。
3、在undo日期中写过更新数据的旧值。如果事物提交失败要回滚数据,可以用undo日志的数据恢复bufferPool里的缓存数据。
4、执行器更新bufferPool中的内存数据。
5、执行器写入redo日志。
6、Redo log buffer准备提交事物,redo日志写入磁盘
7、执行器准备提交事物,binlog日志写入磁盘。
8、写入commit标记到redo日志文件里,提交事物完成,改标记为了保证事物提交后,redo log和bin log 的更新数据一致性。
9、BufferPool通过IO,随机写入磁盘,以page为单位写入。
其他:binlog用来恢复数据的,比如删库跑路,就可以用binlog回复数据库。
redolog作用,buffer pool 里面数据还未写入磁盘,突然mysql突然宕机了,在启动mysql以后,bufferpool会在redo log加载数据,进行写盘。所以只要事物提交成功,数据就不会丢失。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值