iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >02.日志系统:一条SQL更新语句是如何执行的?
  • 357
分享到

02.日志系统:一条SQL更新语句是如何执行的?

02.日志系统:一条SQL更新语句是如何执行的? 2015-02-19 03:02:37 357人浏览 绘本
摘要

   我们还是从一个表的一条更新语句说起,我们创建下面一张表: create table T(ID int primary key, c int);    如果要将ID=2这一行c的值加1,sql可以这么写: update T set

   我们还是从一个表的一条更新语句说起,我们创建下面一张表:

create table T(ID int primary key, c int);

   如果要将ID=2这一行c的值加1,sql可以这么写:

update T set c=c+1 where ID=2;

   前一篇文章介绍过SQL语句基本的执行链路,可以确认的说,查询语句的那一套流程,更新语句也是同样会走一遍。在执行语句前要先连接数据库,这是连接器的工作。接下来,分析器会通过词法和语法解析知道这是一条更新语句,优化器决定要使用ID这个索引。然后执行器负责具体执行,找到这一行,然后更新。

  与查询流程不一样的是,更新流程还涉及两个重要的日志模块:redo log(重做日志)和binlog(归档日志)。

  • redo log

  Mysql里面经常说到的WAL技术的全称是Write-Ahead Logging,它的关键点就是行写日志再写磁盘。具体来说,当有一条记录需要更新的时候,InnoDB引擎会先把记录写到redo log里面,并更新内存,这个时候更新就算完成了。同时InnoDB引擎会在适当的时候,将这个操作记录更新到磁盘里面,而这个更新往往是在系统比较闲的时候做。

  InnoDB的redo log是固定在小的,比如可以配置为一组4个文件,每个文件的大小是1GB,那么总共就可以记录4GB的操作,如图所示:

   从头开始写,写到末尾又回到开头循环写,write pos是当前记录的位置,一边写一边后移,写到3号文件末尾后就回到0号文件开头。checkpoint是当前要擦除的位置,擦出记录前要把记录更新到数据文件中。如果write pos追上checkpoint,这个时候不能再执行新的更新,得停下来先擦除一些记录,把checkpoint推进一下。

   有了redo log,InnoDB就可以保证即使在数据库发生异常重启,之前提交的记录都不会丢失,这个能力称为crash-safe。  

  • binlog

  mysql整体来看,其实就两块:一块是Server层,它主要做的是MySQL功能层面的事情;还有一块就是引擎层,负面存储相关的具体事宜,上面说到的redo log是InnoDB引擎特有的日志,而Server层也有自己的日志,称为binlog。

 为什么会有两份日志呢?因为最开始MySQL并没有InnoDb引擎,MySQL自带的引擎是MyISAM,但MyISAM并没有crash-safe能力,binlog日志只能用于归档。

redo log日志和binlog日志有以下3个不同点:

  1. redo log 是InnoDB引擎特有的;binlog 是MySQL的Server层实现的,所有引擎都可以使用。
  2. redo log 是物理日志,记录的是“在某个数据页上做了什么修改”;binlog是逻辑日志,记录的是这个语句的原始逻辑,比如"给ID=2这一行的c字段+1"。
  3. redo log 是循环写的,空间固定会用完;binlog是可以追加写入的,“追加写”是指binlog文件写到一定的大小后会切换到下一个,并不会覆盖以前的日志。

那么执行一个简单的update语句的内部流程如下:

  1. 执行器先找引擎取ID=2这一行,ID是主键,引擎直接用树搜索找到这一行,如果ID=2这一行所在的数据页本来就在内存中,就直接返回给执行器;否则,需要先从磁盘读入内存,然后返回。
  2. 执行器拿到引擎返回的行数据,把这个值+1,行到新的一行数据,再调用引擎接口写入这行新数据。
  3. 引擎将这行数据更新到内存中,同时将这个更新操作记录到redo log里面,此时redo log处理prepare状态,然后告知执行器执行完了,随时可以提交事务
  4. 执行器生成这条操作的binlog,并把binlog写入磁盘。
  5. 执行器调用引擎的提交事务接口,引擎把刚刚写入redo log改成提交(commit)状态,更新完成。

将redo log的写入折成了两个步骤:prepare和commit,这就是“两阶段提交”。

  • 两阶段提交
  1. 先写redo log 后写binlog。假设在redo log写完后,binlog还没有写完的时候,MySQL进程异常重启,根据redo log恢复回来后这一行数据c=1,但由于binlog没有写完就crash了,这个时候binglog里面就没有这条更新语句,如果需要用这个binlog来恢复临时库的话,这个临时库就会少一次更新,恢复出来的数据c=0。
  2. 先写binlog后写redo log。如果binlog写完之后crash,由于redo log还没有写完,崩溃恢复后这个事务无效,所以这一行的c=0,但时,binlog里面已经记录了c=1,所以之后用binlog恢复出来的数据c=1写原库的值不同。

简单来说,redo log和binlog都可以用于表示事务提交状态,而两阶段提交就是让这两个状态保持逻辑上的一致。

 

您可能感兴趣的文档:

--结束END--

本文标题: 02.日志系统:一条SQL更新语句是如何执行的?

本文链接: https://www.lsjlt.com/news/2366.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么执行一条SQL更新语句
    这篇文章给大家分享的是有关怎么执行一条SQL更新语句的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、前言前面我们系统了解了一个查询语句的执行流程,并介绍了执行过程中涉及的处理模...
    99+
    2024-04-02
  • 一条SQL更新语句的执行过程是什么
    这篇“一条SQL更新语句的执行过程是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“一条SQL更新语句的执行过程是什么”文...
    99+
    2023-06-30
  • 一条SQL更新语句的执行过程解析
    目录一、执行过程二、日志模块1、物理日志redo logredo log的使用场景redolog配置2、逻辑日志binlog两阶段提交binlog使用场景前言: 上一篇文章讲解了SQ...
    99+
    2024-04-02
  • Java MyBatis是如何执行一条SQL语句的
    目录背景阅读环境阅读过程加载XML的过程创建Mapper获得一个Mapper执行一个Mapper的方法结论背景 在前两天的一次面试中,面试官问了一个和标题一样的问题,由于一直认为My...
    99+
    2024-04-02
  • 一条SQL语句在MySQL中是如何执行的
    今天就跟大家聊聊有关一条SQL语句在MySQL中是如何执行的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。前言最近开始在学习mysql相关知识,自己...
    99+
    2024-04-02
  • MySQL中一条SQL查询语句是如何执行的
    目录前言1. 处理连接1.1 客户端和服务端的通信方式1.1.1 TCP/IP协议1.1.2 UNIX域套接字1.1.3 命名管道和共享内存1.2 权限验证1.3 查看MySQL连接...
    99+
    2024-04-02
  • Oracle中sql语句如何执行日志查询
    目录oracle sql语句执行日志查询Oracle查询某天sql执行记录Oracle sql语句执行日志查询 在Oracle数据中,我们经常编写sql语句,有时我们会编写一些特别长的sql语句,而有一些意外导致sql消...
    99+
    2022-12-06
    Oraclesql语句 sql执行日志查询 Oracle执行sql语句
  • 浅谈MyBatis 如何执行一条 SQL语句
    目录前言 基础组件 工作流程 初步使用 详细流程 获取 MapperProxy 对象 缓存执行方法 构造参数 获取需要执行的 SQL 对象 执行 SQL 语句 总结 前言 Myba...
    99+
    2024-04-02
  • Java MyBatis是怎么执行一条SQL语句的
    今天小编给大家分享一下Java MyBatis是怎么执行一条SQL语句的的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下...
    99+
    2023-07-02
  • MySQL中一条update语句是如何执行的
    目录前言前期准备SQL语句的执行过程Update语句分析redo log(重做日志)binlog(归档日志)‍♀️总结前言 上一篇文章说完MySQL的事务和锁了,这次来详细介...
    99+
    2024-04-02
  • Mybatis执行多条语句/批量更新的方法是什么
    本篇内容主要讲解“Mybatis执行多条语句/批量更新的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Mybatis执行多条语句/批量更新的方法是什么”吧!Mybatis执行多条语句/...
    99+
    2023-07-05
  • 腾讯面试:一条SQL语句执行得很慢的原因有哪些?---不看后悔系列(推荐)
    说实话,这个问题可以涉及到 MySQL 的很多核心知识,可以扯出一大堆,就像要考你计算机网络的知识时,问你“输入URL回车之后,究竟发生了什么”一样,看看你能说出多少了。 之前腾讯面试的实话,也问到这个问题...
    99+
    2024-04-02
  • 如何利用MySQL和Go语言开发一个简单的日志管理系统
    如何利用MySQL和Go语言开发一个简单的日志管理系统引言:日志是软件开发中经常用到的重要组成部分,它可以帮助我们追踪问题、记录用户操作、监控系统性能等。在本文中,我将通过结合MySQL和Go语言,教你如何开发一个简单的日志管理系统,并提供...
    99+
    2023-10-22
    MySQL Go语言 日志管理系统
  • 运行在Docker里的SpringBoot应用是如何查看记录在文件系统的日志
    运行在Docker里的SpringBoot应用是如何查看记录在文件系统的日志,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。我有一个SpringBoot应用,将其...
    99+
    2023-06-04
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作