MySql 深入浅出之二 (Update的执行)

前面说到了数据库的查询会经过连接器,分析器,执行器,存储engine等。试下,在一条更新语句之前,我们必须知道更新前的值,因此在Update执行的时候,查询语句也会先被走一边。下图是一个Update语句执行的过程:

从图中可以看出两个重要的日志用于完成update这一操作。其中 redo log是用于保存物理日志的,用于记录这个数据页修改了什么操作,存放在存储Engine中,是InnoDB自带的;而bin log是用于保存逻辑日志的,用于记录SQL的原始逻辑,比如给ID = 1 中的字段C➕1,是在server层中的log,是所有引擎都共用的。

这种方式叫做Mysql的二阶段提交。其中redo log 具有crash—safe作用。能保证数据库在异常重启的时候数据也不会丢失。同时使用二阶段提交的作用是保证数据库在crash恢复后数据也能保持一致。

为了保证update的效率,数据库不是每次update都会将数据写入磁盘。他是会先写在内存中,等待数据库不那么繁忙的时候再将数据从内存写入磁盘中。 所以也体现了这两个日志的重要性。 如果没有这两个日志,数据库就无法达到“可以恢复到八个月前任一时段状态”的指标。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值