首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL一条SQL语句的执行过程

一条select语句执行流程 第一步:连接器 连接器负责跟客户端建立连接、获取权限、维持和管理连接。如果用户名密码验证通过后,连接器会到权限表里面查出你拥有的权限。...第二步:查询缓存 当获取连接后,一条SELECT语句会先去查询缓存,看之前是否执行过。如果获取到缓存后就执行返回,不然继续后面的步骤。...MYSQL8版本直接将查询缓存的整块功能删掉了。 第三步:分析器 分析器首先会做“词法分析”,MYSQL会识别出SQL语句里面的字符串是什么以及代表什么。...打开表的时候,执行器就会根据表的引擎定义,去使用这个引擎提供的接口。 图片 一条update语句执行流程 update语句除了会执行上面的五步,还会涉及两个重要的日志模块。...两个重要的日志模块 redo log (重做日志) redo log 是innodb所特有的,当有一条更新语句时,innoDB引擎会先把记录写到redo log中,然后更新内存,这时候更新就算完成了。

22620
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Linux 从头学 01:CPU 是如何执行一条指令的?

    CPU 其实是一个很纯粹、很呆板的一个东西,它唯一做的事情就是:到 CS:IP 这两个寄存器指定的内存单元中取出一条指令,然后执行这条指令: ?...当然了,还需要预先定义一套指令集,在内存中的指令区中,存储的都必须是合法的指令,否则 CPU 就不认识了。 每一条指令都是用某些特定的数(指令码)来指示 CPU 进行特定的操作。...CPU 执行指令流程 现在我们已经明白了地址转换、内存的寻址,距离 CPU 执行一条指令需要的最小单元还剩下:指令缓冲区和控制电路。...B8 23 01,经过数据总线被送到指令缓冲区; 指令偏移寄存器 IP 的值要加 3,指向下一条等待被执行的偏移地址(因为指令码 B8 代表当前指令的长度是 3 个字节); 执行指令缓冲区中的指令:...把数值 0123H 送入寄存器 AX 中; 以上就是一条指令执行最基本步骤,当然,现代处理器的指令执行流程,比这里的要复杂的多得多。

    1.1K20

    MySQL一条更新的SQL如何执行

    MySQL 之 -- 一条更新的 SQL 如何执行一条更新的 SQL 语句如何执行执行流程一条 SQL 的执行流程如图所示:(图片来源于网络) 如图所示:MySQL 数据库主要分为两个层级:服务层和存储引擎层服务层...执行流程 一条 SQL 的执行流程如图所示:(图片来源于网络) 如图所示: MySQL 数据库主要分为两个层级:服务层和存储引擎层 服务层:server 层包括连接器、查询缓存、分析器、优化器、执行器...存储引擎也可以在创建表的时候手动指定,比如: SQL 语句的执行过程 连接器:需要 MySQL 客户端登录,需要一个 连接器 来连接用户和 MySQL 数据库,“mysql -u 用户名 -p 密码”...词法分析:首先,MySQL 会根据 SQL 语句进行解析,分析器会先做 词法分析,你写的 SQL 就是由多个字符串和空格组成的一条 SQL 语句,MySQL 需要识别出里面的字符串是什么,代表什么。...执行器:在执行阶段,MySQL 首先会判断有没有执行语句的权限,若无权限,返回没有权限的错误;若有权限,就打开表继续执行

    1.2K10

    MySQL : 彻底搞懂一条SQL的执行过程

    /www.bilibili.com/video/BV1Gg411z7Zi 整体流程 image.png 组件介绍 连接器 处理客户端的连接,一般处理我们这个命令,判断是否满足接入server的条件 mysql...经过分析器之后,我们最终就能生成一个语法树,后续执行引擎执行语句,就得靠这个语法树进行 优化器 在经过分析器之后,mysql需要做的是对我们的sql进行一定的优化,那么它做了哪些优化呢 决定使用哪个索引...调整where 字段位置:如建立了一个联合索引 abc,但是我们的where 条件是这么写的 where b =1 and a=2 and c=4,这样写肯定不满足最左前缀匹配原则的,所以mysql决定给你优化下...,直接调整成这样:where a=2 and b=1 and c=4,最终使用到了索引;但是如果 写成where b=1 and a=2,没有c字段,mysql是不会给你优化的。...执行器 调用不同的索引存储引擎API,执行解析后的sql

    76440

    一条SQL的执行来看看Mysql架构

    当我们在项目中使用mybatis框架执行一条mysql语句时,会经历如下过程: ?...mysql客户端(项目)连接mysql服务端,主要作用是验证客户端的用户密码、权限等、这一步一般发生在项目启动初始化时,连接器验证通过后将连接对象保存到内存中,以便使用。...mysql客户端与服务端连接后,会判断这条语句是否命中查询缓存,命中直接返回查询结果,否则进去分析器。 分析器的主要功能是检查语法是否正确。...将调优后的sql方案传给执行器,执行器调用相应的存储引擎接口,如果是查询语句直接进行执行步骤,比如这条Sql有两个条件,会分解为两步判断。...总结: 1.mysql主要分为Server层和引擎层,Server层主要包括连接器、查询缓存、分析器、优化器、执行器同时还有一个binlog日志模块,redolog只有InnoDB引擎所有,引擎层主要有

    54750

    MySQL一条更新的SQL如何执行

    MySQL 之 -- 一条更新的 SQL 如何执行一条更新的 SQL 语句如何执行执行流程一条 SQL 的执行流程如图所示:(图片来源于网络) 如图所示:MySQL 数据库主要分为两个层级:服务层和存储引擎层服务层...执行流程 一条 SQL 的执行流程如图所示:(图片来源于网络) 如图所示: MySQL 数据库主要分为两个层级:服务层和存储引擎层 服务层:server 层包括连接器、查询缓存、分析器、优化器、执行器...存储引擎也可以在创建表的时候手动指定,比如: SQL 语句的执行过程 连接器:需要 MySQL 客户端登录,需要一个 连接器 来连接用户和 MySQL 数据库,“mysql -u 用户名 -p 密码”...词法分析:首先,MySQL 会根据 SQL 语句进行解析,分析器会先做 词法分析,你写的 SQL 就是由多个字符串和空格组成的一条 SQL 语句,MySQL 需要识别出里面的字符串是什么,代表什么。...执行器:在执行阶段,MySQL 首先会判断有没有执行语句的权限,若无权限,返回没有权限的错误;若有权限,就打开表继续执行

    92610

    一条指令执行,居然只需要这5个步骤!

    我是一条指令,我现在慌得一批 我是一条指令,在被CPU处理5次后,即将被销毁释放,我现在慌得一批。 毕竟,主存的空间是有限的,被执行完的我也失去了存在的价值。...但当时的我认为,既然出生在核心,那就意味着重要,没有什么比这更使得指令快乐的了。 我是一条二地址指令,虽然我也不明白什么是二地址指令,但是大家都这么叫我。...之所以被大家称作二地址指令,是因为我有两个数据地址。 等待被执行 在冯·诺依曼体系中,一切事物的表现形式都是二进制数据,所以我看了看前后左右的朋友,他们的模样的确都和我类似。...这下我想起来了,在我出现在主存之前,我曾见到过我的上一世: 123+321 开始执行 我是一条指令,我已进入指令寄存器,感觉良好。...计算电路将按照严格的逻辑执行加法运算,将两个数据加在一起求和,当然,结果也是二进制的形式。

    67920

    一条SQL语句在MySQL中如何执行

    前两天发了一条SQL慢的原因有哪些,在那篇文章我没有说到优化器之类的,我觉得如果配合一条SQL是如何执行的,会更好,所以特地找了一篇。...3) 分析器 MySQL 没有命中缓存,那么就会进入分析器,分析器主要是用来分析 SQL 语句是来干嘛的,分析器也会分为几步: 第一步,词法分析,一条 SQL 语句有多个字符串组成,首先要提取关键字,比如...二 语句分析 2.1 查询语句 说了以上这么多,那么究竟一条 sql 语句是如何执行的呢?其实我们的 sql 可以分为两种,一种是查询,一种是更新(增加,更新,删除)。...进行权限校验,如果没有权限就会返回错误信息,如果有权限就会调用数据库引擎接口,返回引擎的执行结果。 2.2 更新语句 以上就是一条查询 sql 的执行流程,那么接下来我们看看一条更新语句如何执行的呢?...,同时主从同步也会丢失这一条数据。

    3.5K20

    【SQL】Mysql一条sql语句的执行过程

    接下来,通过一条sql语句的执行来深入了解MySQL各个组件功能以及其作用。...至此,一条查询语句的执行流程已经非常清晰了,同时也认识了MySQL的整个体系结构以及各组件的作用。最后用一张图来收尾本文的核心内容并做总结。...一条查询SQL语句的执行流程: 客户端通过连接器连接MySQL服务。 连接成功后向SQL接口发送SQL语句请求。...二 语句分析 2.1 查询语句 说了以上这么多,那么究竟一条 sql 语句是如何执行的呢?其实我们的 sql 可以分为两种,一种是查询,一种是更新(增加,更新,删除)。...2.2 更新语句 以上就是一条查询 sql 的执行流程,那么接下来我们看看一条更新语句如何执行的呢?

    43410

    MySQL一条SQL语句是如何执行的?

    例如一个简单的SQL语句: mysql> select * from T where ID=10; ? 在 MYSQL 内部是怎么执行的呢?我们从头梳理一下。...执行器 知道了做什么、怎么做,下面就是真正开始干了,由执行器负责具体执行。...执行器的基本执行逻辑: 调用存储引擎“取满足条件的第一行”这个接口,然后循环取“满足条件的下一行”这个接口,将所有满足条件的行组成结果集返还给客户端。 ? 至此,这个语句就执行完了。...MySQL 整体结构 ? 总体来说,MySQL 分为2个层次:server 层、存储引擎层。...server 层包括连接器、分析器、优化器、执行器,涵盖 MySQL 的核心服务,以及所有的内置函数(如日期、时间、数学、加密函数等),还有所有跨存储引擎的功能,例如存储过程、触发器、视图等。

    1.5K20

    一条指令引发的血案···

    然后是函数结束返回的地方,要恢复栈空间,使用了add, esp, 298h指令: 聪明的你一定已经发现问题了,怎么开始是用的rsp寄存器,后面用的是esp寄存器呢?...x64兼容了x86指令集,可以通过esp访问rsp的低32位。 先别往下看,你先猜一下,这里会出问题吗,为什么会出问题呢?...由于前面正好有一堆nop,于是将紧邻着的一个nop从0x90改为0x48,这样一来,就把add esp, 298h这条指令,改成了add rsp, 298h了。...等等,再看一下寄存器: 发现了一个很可疑的点,在执行了add esp, 298之后,相比rbp,rsp丢失了高32位,这也就是说……高32位被置零了?...再来动态调试验证一下,执行add esp, 298之前: 执行add esp, 298之后: 这里就很明确了,确实在执行add esp后,高32位被置零了。 这是为啥嘞?

    7310

    MySQL实战 | MySQL逻辑架构—一条查询SQL是如何执行

    执行如下SQL,我们看到的只是输入一条语句,返回一个结果,却不知道这条语句在 MySQL 内部的执行过程。...一条SQL查询的完整执行流程如上图所示。 Server服务层 连接器 连接数据库最开始肯定是连接器。连接器负责跟客户端建立连接、获取权限、维持和管理连接。...如果你用的是 MySQL 5.7 或更新版本,可以在每次执行一个比较大的操作后,通过执行 mysql_reset_connection 来重新初始化连接资源。...你输入的是由多个字符串和空格组成的一条 SQL 语句,MySQL 需要识别出里面的字符串分别是什么,代表什么。 MySQL 从你输入的"select"这个关键字识别出来,这是一个查询语句。...如果能够首先进行最严格的测试,查询就可以执行地更快。 执行MySQL 通过分析器知道了你要做什么,通过优化器知道了该怎么做,于是就进入了执行器阶段,开始执行语句。

    1.2K30

    Mysql进阶篇--一条sql查询语句如何执行

    在开发阶段我们经常使用查询语句,但是一条语句的查询是如何执行的呢,如下语句 mysql> select * from depart; 日常中,我们只看到返回一条或多条结果,并没有过多的去关注查询语句具体要执行那些流程...,如果客户端有请求一直会是同一个连接,短连接是执行多次查询之后会断开,重新再次连接,默认时间是8小时,可以使用参数wait_timeout配置。...定期断开长连接,使用一段时间之后,或者在一个大的查询执行之后,断开重新,之后查询重新链接 如果使用的mysql5.7以及以上,可以使用mysql_restart_connection来初始化链接资源...line 1 由于你少打了一个s,就会保存提示You have an error in your SQL syntax 优化器 进过了分析器,知道了sql语句的含义,接下来,我们就要进行优化器的处理,一条语句的执行是有多个索引的...执行器 分析器分析你要干什么,优化器分析你要怎么执行,真正的执行是在执行器中执行 一条语句的执行,在判断查询的表是否有权限,如果没有返回报错,如果有权限直接打开表,然后根据表的引擎定义,使用引擎的查询接

    95520

    一条SQL语句在MySQL中是如何执行

    分析器 mysql 没有命中缓存,那么就会进入分析器,分析器主要是用来分析SQL语句是来干嘛的,分析器也会分为几步: 第一步,词法分析,一条SQL语句有多个字符串组成,首先要提取关键字,比如select...第二步,语法分析,主要就是判断你输入的sql是否正确,是否符合mysql的语法。 完成这2步之后,mysql就准备开始执行了,但是如何执行,怎么执行是最好的结果呢?这个时候就需要优化器上场了。...二、语句分析 2.1 查询语句 说了以上这么多,那么究竟一条sql语句是如何执行的呢?其实我们的sql可以分为2中,一种是查询,一种是更新(增加,更新,删除)。...进行权限校验,如果没有权限就会返回错误信息,如果有权限就会调用数据库引擎接口,返回引擎的执行结果。 2.2 更新语句 以上就是一条查询sql的执行流程,那么接下来我们看看一条更新语句如何执行的呢?...,同时主从同步也会丢失这一条数据。

    2K20

    一条查询SQL在MySQL中是怎么执行

    平时我们使用的数据库,看到的通常是一个整体,比如我们执行一条查询SQL,返回一个结果集,却不知道这条语句在MySQL内部是如何执行的,接下来我们就来简单的拆解一下MySQL,看看MySQL是由哪些“零件...这样在我们以后遇到MySQL的一些异常或者问题的时候,就可以快速定位问题并解决问题。 下边通过一张图来看一下SQL的执行流程,从中可以清楚的看到SQL语句在MySQL的各个功能模块中执行的过程。 ?...从图中我们可以看到Server层由多个组件,从连接器开始到执行器,接下来我们使用一条简单的查询语句,来依次分析每个组件的作用。...如果MySQL版本是5.7或以上版本,可以在每次执行一个比较大的操作后,通过执行mysql_reset_connection来重新初始化连接资源。...优化器阶段完成后,这个SQL语句的执行方案就确定下来了,进入执行阶段。 执行器 通过前面几步操作,MySQL已经知道了你要做什么,也优化了做的方式,就进入执行器阶段,开始执行语句。

    4.8K20
    领券