• mysql(二) update语句执行过程


    上篇文章 学习了 mysql的基础架构,理清了一条查询sql在mysql中的执行过程,其实update语句的执行过程也是大致相同的。

      以下面的一条sql为例 (ID为主键)

    update T set b=b+1 where ID = 2
    1. 客户端通过连接器与mysql建立连接 
    2. 删除要update表的缓存
    3. 分析器解析sql并判断是否含有语句错误
    4. 优化器确定查询索引
    5. 执行器调用Innodb存储引擎接口获取ID=2的数据行。
    6. Innodb存储引擎扫描主键索引查找到ID=2的行返回给server层。
    7. 执行器将B+1 调用存储引擎接口写入该行数据。
    8. Innodb存储引擎将数据保存在内存中(WAL)。
    9. Innodb存储引擎写redo日志,prepare状态,通知Server层。
    10. server层 提交Binlog后通知Innodb存储引擎。
    11. Innodb存储引擎将redo日志commit。

      至此一条update语句就执行完成了。

      redo日志:Innodb存储引擎特有的机制,可以用来应对异常恢复,Crash-safe,redo可以保证mysql异常重启时,将未提交的事务回滚,已提交的事务安全落库。

      二阶段提交:redo(perpare)--->binlog-->redo(commit) 保证了mysql在异常重启的时候,数据的一致性,在任意环节出错,都可以保证redo日志和binlog的一致性。

      WAL:第8个步骤,innodb没有直接将数据落盘,而是存在内存中,并记录日志,这里用到的技术就是WAL(Write-Ahead Logging)。数据在持久化硬盘前,如果mysql异常重启,innodb可以根据redo日志将未持久化的数据恢复。redo日志是有大小限制的,循环写,当redo快要写满时,将redo日志头部的记录清理,擦除记录前要把内存记录更新到数据文件。

      binLog: binlog 记录的是逻辑日志,是mysql的归档日志,支持所有引擎使用。与redo不同的是,binlog是不限制大小,文件追加写。

    这里将老师的图贴上(对应的5--11的步骤)

      

  • 相关阅读:
    MP3/4维修全攻略
    看图学维修mp3之电源篇65Z8\65Z5
    CSS按钮样式之button标签与input type=button的区别详解
    【原】PNG的使用技巧
    【原】[webkit移动开发笔记]之禁止触发系统默认菜单
    【原】使用iScroll.js解决ios4下不支持position:fixed的问题
    【原】YUI压缩与CSS media queries下的bug
    【翻译】Building a Simple Blog Engine with ASP.NET MVC and LINQ Part 2
    【翻译】Building a Simple Blog Engine with ASP.NET MVC and LINQ Part 4
    .NET技术书籍推荐
  • 原文地址:https://www.cnblogs.com/jasonbourne3/p/12530069.html
Copyright © 2020-2023  润新知