MySQL更新语句执行过程

2023-10-27

  首先要提到的是MySQL更新语句的执行过程,同样也遵守查询数据查询的流程:
MySQL体系结构和数据查询的执行过程
  与查询流程不一样的是,更新流程还涉及重要的日志模块:

总体来说:
1、首先客户端通过tcp/ip发送一条sql语句到server层的SQL interface
2、SQL interface接到该请求后,先对该条语句进行解析,验证权限是否匹配
3、验证通过以后,分析器会对该语句分析,是否语法有错误等
4、接下来是优化器器生成相应的执行计划,选择最优的执行计划
5、之后会是执行器根据执行计划执行这条语句。在这一步会去open table,如果该table上有MDL,则等待。如果没有,则加在该表上加短暂的MDL(S)(如果opend_table太大,表明open_table_cache太小。需要不停的去打开frm文件)
6、进入到引擎层,首先会去innodb_buffer_pool里的data dictionary得到表信息
7、通过元数据信息,去lockinfo里查出是否会有相关的锁信息,并把这条update语句需要的
锁信息写入到lockinfo里
8、然后涉及到的老数据通过快照的方式存储到innodb_buffer_pool里的undo page里,并且记录undo log修改的redo(如果data page里有就直接载入到undo page里,如果没有,则需要去磁盘里取出相应page的数据,载入到undo page里)
9、在innodb_buffer_pool的data page做update操作。并把操作的物理数据页修改记录到redo log buffer里,由于update这个事务会涉及到多个页面的修改,所以redo log buffer里会记录多条页面的修改信息。因为group commit的原因,这次事务所产生的redo log buffer可能会跟随其它事务一同flush并且sync到磁盘上
10、同时修改的信息,会按照event的格式,记录到binlog_cache中。(这里注意binlog_cache_size是transaction级别的,不是session级别的参数,一旦commit之后,dump线程会从binlog_cache里把event主动发送给slave的I/O线程)
11、之后把这条sql,需要在二级索引上做的修改,写入到change buffer page,等到下次有其他sql需要读取该二级索引时,再去与二级索引做merge
(随机I/O变为顺序I/O,但是由于现在的磁盘都是SSD,所以对于寻址来说,随机I/O和顺序I/O差距不大)
12、此时update语句已经完成,需要commit或者rollback。这里讨论commit的情况,并且双1
13、commit操作,由于存储引擎层与server层之间采用的是内部XA(保证两个事务的一致性,这里主要保证redo log和binlog的原子性),
所以提交分为prepare阶段与commit阶段
14、prepare阶段,将事务的xid写入,将binlog_cache里的进行flush以及sync操作(大事务的话这步非常耗时)
15、commit阶段,由于之前该事务产生的redo log已经sync到磁盘了。所以这步只是在redo log里标记commit
16、当binlog和redo log都已经落盘以后,如果触发了刷新脏页的操作,先把该脏页复制到doublewrite buffer里,把doublewrite buffer里的刷新到共享表空间,然后才是通过page cleaner线程把脏页写入到磁盘中

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

MySQL更新语句执行过程 的相关文章

随机推荐

  • VS2019 + libcurl5.7.0 + openssl3.0.5 简易编译教程

    VS2019 libcurl5 7 0 openssl编译配置 1 用途 工作用到C 对求高德地图发送https请求 进行逆地址分析 2 文件包下载 2 1 window的openssl3 0 5EXE安装包 链接 exe安装包 2 2 下
  • numpy求平均值

    本文转自链接 https www cnblogs com yibeimingyue p 11413295 html 1 对数组求平均值 import numpy as np a np array 1 2 3 4 print a print
  • C语言问题汇总

    C语言问题汇总 排序方法 冒泡排序 降序排序 作业 从文件中读取内容 字符写入文件 结构体数组 以二进制形式写入文件并读取 将字符串写入文件 并从文件中读取 查找字符在字符串中的位置 字符串链接 不使用strcpy函数 使用strcpy函数
  • 俄罗斯方块C++代码(转载他人代码)

    include
  • (ctf)攻防世界web模块020web2

    题目 首先来到给定的地址 题意很明确 miwen是加密之后的字符串 我们只需要逆向解密出miwen就能得到flag 我们先来代码审计 o strrev str strrev 函数是字符串的倒置 for 0 0 0
  • java.io.IOException: Connection reset by peer问题解决

    java io IOException Connection reset by peer问题解决 今天检查日志 发现 ClientAbortException java io IOException Connection reset by
  • font-spider(字蛛)的正确打开方式

    前言 最近在部署vue项目之后 在打开网页的时候 ttf文件下载时间实在是太久了 在经过合理的运用搜索引擎之后 可能自己的固化思维消化不了大佬们给出的方案 于是在他们的基础之上做了一些小小的改动 便叙文记之 1 引入font spider的
  • BigDecimal 前端丢失精度的问题解决

    问题描述 后端数字是85 00 但是前端显示85 SQL语句 select cast 字段 as decimal 10 2 value 这里已经保留两位小数了 from table where 实体类 这里是关键 注意不是 JSONFiel
  • java 的JDBC操作

    JDBC java数据库连接 提供了一套数据库操作标准 这些标准需要各个数据库厂商去实现并提供一个驱动程序 目前常见的4类JDBC驱动程序 JDBC ODBC 直接利用微软的ODBC进行数据库连接操作 性能低 一般不推荐 JDBC本地驱动
  • 前端笔记

    发布在github的笔记 下载慢 所以我放到csdn上面了 源地址 https github com overcomputer JavaScript 源地址 关注 大佬发布在github的笔记 下载慢 所以我放到csdn上面了 源地址 ht
  • Android HandlerThread 总结使用

    前言 以前我在 Android Handler Loop 的简单使用 介绍了子线程和子线程之间的通信 很明显的一点就是 我们要在子线程中调用Looper prepare 为一个线程开启一个消息循环 默认情况下Android中新诞生的线程是没
  • 一招教你学会使用AD更改PCB板子尺寸

    使用原理图生成PCB后 Altium Designer会根据原理图大小自动生成一块黑色区域 还有一个在禁止布线层的方框 还有两段标注板子大小的线 下面说一下如何更改黑色区域的大小 还有如何精确确定板子尺寸 比如使其为长宽都为整数 1 调整
  • 【浙工商期末报告】研一R语言期末作业(源代码分享)

    目录 研一R语言期末作业 源代码分享 一 作业回顾 1 1 计算t值 1 2 绘图 二 结果展示 2 1 计算t值 2 2 绘图 三 源代码分享 一 作业回顾 1 1 计算t值 1 2 绘图 二 结果展示 2 1 计算t值 1 1 9379
  • 【Flutter 2-9】Flutter手把手教程UI布局和Widget——弹性布局控件Flexible

    作者 弗拉德 来源 弗拉德 公众号 fulade me Flexible Flexible可以帮助Row Column Flex的子控件充满父控件 它的用法很灵活 也具有权重的属性 跟Flexible相类似的控件还有Expanded 先来看
  • MVC模式和三层架构

    MVC模式和三层架构 MVC 模式和三层架构是一些理论的知识 将来我们使用了它们进行代码开发会让我们代码维护性和扩展性更好 MVC模式 MVC是一种分层开发的模式 其中 M Model 业务模型 处理业务 V View 视图 界面展示 C
  • vscode软件打开失败(闪退)---兼容性问题

    1 右击vscode 选择 兼容性疑难解答 2 选择 尝试建议的设置 3 测试程序 4 vscode自动打开 问题解决 5 关闭vscode 6 下一步即可
  • 香橙派 Orangepi Zero2配置网络SSH登录

    1 命令扫描周围的WIFI热点 nmcli dev wifi 2 接入网络命令 nmcli dev wifi connect WIFI名称 password WIFI密码 用ifconfig获取IP地址 3 选择SSH登录 4 输入密码后就
  • 关于应用spdlog日志库的一些学习心得

    前后从小白到勉强能够使用spdlog日志库前后就几天时间吧 到现在有时间好好静下来反思一下学习步骤 想想哪一步还能再继续改进 刚入手时 看到的代码都是以往的学长们动过的 代码阅读难度大 基本上是缺失太多的东西了 后面才发现可以从GitHub
  • 【野火】瑞萨RA MCU创意氛围赛+基于瑞萨单片机的环境温湿度监测装置

    野火 瑞萨RA MCU创意氛围赛 基于瑞萨单片机的环境温湿度监测装置 1 设计简介 2 硬件设计 2 1主控板 2 2DHT11温湿度采集模块 2 3SPI屏幕 3 软件设计 4 效果展示 5 部分代码 功能 1 通过DHT11温湿度模块采
  • MySQL更新语句执行过程

    首先要提到的是MySQL更新语句的执行过程 同样也遵守查询数据查询的流程 MySQL体系结构和数据查询的执行过程 与查询流程不一样的是 更新流程还涉及重要的日志模块 MySQL日志之二进制日志binlog MySQL日志之重做日志redo