第二部: 查询缓存 mysql拿到请求后首先判断请求的查询语句是否有缓存,是否命中缓存,但是不推荐使用mysql的缓存,官方也不推荐,因为只要有一条数据更新表的缓存就会被删除,降低效率 第三步: ...分析器 没有命中缓存的话就要开始执行语句了,首先对sql语句进行解析, 首先做 “词法解析”,分析出sql语句的关键词等字符串代表什么含义,然后通过”语法分析“判断这个sql是否满足语法标准。...第四步: 优化器 优化sql执行的速度,比如执行的索引、表连接(join)的执行顺序,然后决定出最快的执行方案 第五步: 执行器 判断用户对这个表是否有权限,有的话就会根据这个表的引擎执行通过优化器给出的最优执行方案去执行
这篇笔记主要记录MySQL的基础架构,一条查询语句是如何执行的。...比如,在我们从student表中查询一个id=2的信息 select * from student where id=2; 在解释这条语句执行流程之前,我们看看MySQL的基础架构。...缓存的工作流程是 服务器接收SQL,以SQL和一些其他条件为key查找缓存表 如果找到了缓存,则直接返回缓存 如果没有找到缓存,则执行SQL查询,包括原来的SQL解析,优化等。...大多数查询优化器,包括MySQL的查询优化器,总或多或少地在所有可能的查询评估方案中搜索最佳方案。 优化器主要是选择一个最佳的执行方案,执行方案是为了减少开销,提高执行效率。...总结 MySQL得到sql语句后,大概流程如下: 0.连接器负责和客户端进行通信 1.查询缓存:首先查询缓存看是否存在k-v缓存 2.解析器:负责解析和转发sql 3.预处理器:对解析后的sql树进行验证
一直是想知道一条 SQL 语句是怎么被执行的,它执行的顺序是怎样的,然后查看总结各方资料,就有了下面这一篇博文了。...本文将从 MySQL 总体架构 -> 查询执行流程 -> 语句执行顺序来探讨一下其中的知识。 MySQL 架构总览 架构最好看图,再配上必要的说明文字。...查询执行流程 下面再向前走一些,容我根据自己的认识说一下查询执行的流程是怎样的: 连接 客户端发起一条 Query 请求,监听客户端的连接管理模块接收请求; 将请求转发到连接进/线程模块; 调用用户模块来进行授权检查...,检查权限等,生成新的解析树; 再转交给对应的模块处理; 如果是 SELECT 查询还会经由‘查询优化器’做大量的优化,生成执行计划; 模块收到请求后,通过访问控制模块检查所连接的用户是否有访问目标表和目标字段的权限...「应用」: 对主表的过滤应该放在 WHERE; 对于关联表,先条件查询后连接则用 ON,先连接后条件查询则用 WHERE。
作者 :AnnsShadoW 来源:www.cnblogs.com/annsshadow 一、前言 一直是想知道一条SQL语句是怎么被执行的,它执行的顺序是怎样的,然后查看总结各方资料,就有了下面这一篇博文了...本文将从MySQL总体架构--->查询执行流程--->语句执行顺序来探讨一下其中的知识。 二、MySQL架构总览 架构最好看图,再配上必要的说明文字。...三、查询执行流程 下面再向前走一些,容我根据自己的认识说一下查询执行的流程是怎样的: 1、连接 1.1、客户端发起一条Query请求,监听客户端的‘连接管理模块’接收请求; 1.2、将请求转发到‘连接进...‘查询优化器’做大量的优化,生成执行计划; 2.6、模块收到请求后,通过‘访问控制模块’检查所连接的用户是否有访问目标表和目标字段的权限; 2.7、有则调用‘表管理模块’,先是查看table cache...ON,先连接后条件查询则用WHERE; ?
MySQL语句的执行流程 下图是一条查询sql语句的执行流程: ? 1.1 通信协议 我们的程序或者工具要操作数据库,第一步要做什么事情?当然是跟数据库建立连接。...但是如果有这么多种执行方式,这些执行方式怎么得到的? 最终选择哪一种去执行?根据什么判断标准去选择?这个就是 MySQL 的查询优化器的模块(Optimizer)。...当然,这个执行计划是不是一定是最优的执行计划呢?不一定,因为 MySQL 也有可 能覆盖不到所有的执行计划。我们怎么查看 MySQL 的执行计划呢?比如多张表关联查询,先查询哪张表?...在执行查询的时候可能用到哪些索引,实际上用到了什么索引? MySQL 提供了一个执行计划的工具。我们在 SQL 语句前面加上 EXPLAIN,就可以看到执行计划的信息。...更新语句的执行流程: 讲完了查询流程,我们是不是再讲讲更新流程、插入流程和删除流程?更新流程和查询流程有什么不同呢?基本流程也是一致的,也就是说,它也要经过解析器、优化器的处理,最后交给执行器。
当希望 MySQL 能够以高性能的方式运行查询时,最好的办法就是弄清楚 MySQL 是如何优化和执行查询的。MySQL 执行一个查询的过程,如下: ?...【4】MySQL 根据优化器生成的执行计划,调用存储引擎的 API 来执行查询。优化器是在表里面有多个索引的时候,决定使用哪个索引。...所以,我们根据执行成本选择执行计划并不是完美的模型。 【4】MySQL 从不考虑其他并发执行的查询:可能会影响到当前查询的速度。...五、执行计划 ---- 和很多其他关系数据库不同,MySQL 并不会生成查询字节码来执行查询。MySQL 生成查询的一颗指令树,然后通过存储引擎执行完成这棵指令树并返回结果。...六、查询执行引擎 ---- 在解析和优化阶段,MySQL 将生成查询对应的执行计划,MySQL 的查询执行引擎则根据这个执行计划来完成整个查询。这里执行计划是一个数据结构,而不是字节码。
mySQL查询执行的过程 01 查询的流程图 当我们希望MySQL能够以更高的性能进行查询时,弄清楚MySQL中是如何优化和执行查询的就显得很有必要,这里,先搬出来一张图镇楼: ?...这张图写清楚了一个查询在MySQL中的执行过程: 1、客户端发送一条查询给服务器。 2、服务器先检查查询缓存,如果命中了缓存,则会进行权限校验,权限校验通过,直接返回结果。...3、如果没有命中缓存,则进行SQL解析、预处理、再由优化器进行查询优化,计算各项查询方法的成本、生成对应的执行计划。 4、MySQL根据执行计划,调用存储引擎的API来执行查询。...在我们查询的过程中,MySQL会维护一个查询状态,也就是我们使用show processlist来进行查看的时候的一些状态值,例如: sleep,说明线程正在等待客户端发送新的请求 query,线程正在执行查询或者正在将结果发送给客户端...04 查询的优化处理 查询优化处理包含多个部分,例如解析SQL、预处理、优化SQL执行计划等等,其中: 语法解析器是专门的解析MySQL语法的,一旦发现错误的关键字、数据类型、关键字顺序、字段和数值顺序等等
Mysql SQL查询处理的顺序: (8)select (9)distinct (1)from (3) join (10)order by (11)limit 第一个被处理的子句总是from,最后执行的是...limit,每个操作都会产生一个虚拟表,做为下一步的输入,这个虚拟表对用户是透明的,只有最后一个虚拟表才会返回给用户 (1)from 对和执行笛卡尔积...的记录放入VT2 (3)join 如果指定了join类型,如 left join、right join,把相应的外部行添加到VT2,形成VT3 如果from中有两个以上的表,使用VT3和下一个表再执行一遍前
MySQL 8.0 SQL 执行流程首先我们先来看下 MySQL 的经典架构图,8.0 的没怎么翻到,先看看这个了。...解析器先提取相应的关键词,然后进行语法解析,判断 SQL 是否符合相应的语法,然后生成语法树,上面拆分了 SQL 的各种成分,比如查询字段、查询表、匹配条件等。...作用是在每次查询时将结果缓存,然后再次查询可以加快访问速度,但是因为命中率太低,有点鸡肋所以在 MySQL 8.0已经不存在了。...Pluggable storage Engines数据库的执行引擎插件。文件系统这个是存放 MySQL 的文件系统。...SQL 执行流程SQL 流程是 SQL --> 解析器 --> 优化器 --> 执行器 --> 返回结果。下面会将各个组件单独拉出来做分析。
一、update跟踪执行配置 使用内部程序堆栈跟踪工具path_viewer,跟踪mysql update 一行数据的执行过程,配置执行脚本:call_update.sh DROP DATABASE.../util/seperate.sh $TOPIC 10000 5 ~ 执行后,生成执行结果: path_viewer...> LEX::make_sql_cmd(Parse_tree_root*) > PT_update::make_cmd(THD*) # 更新流程...calc_row_difference row_update_for_mysql row_upd_step row_upd --执行更新 btr_pcur_t::restore_position...三、执行总结 update执行流程 1.执行语句连接数据库 2.分析器通过词法、语法分析知道这是一条更新语句 3.优化器确定执行路径 4.执行器具体执行,找到这一行,更新数据,然后通过Inodb存储具体更新操作
当我们希望MySQL能够以更高的性能运行查询时,最好的办法就是弄清楚MySQL是如何优化和执行查询的。...服务器端进行SQL解析、预处理,再由优化器生成对应的执行计划 MySQL根据优化器生成的执行计划,调用存储引擎的API来执行查询 将结果返回客户端 MySQL客户端/服务器通信协议 MySQL客户端和服务器之间的通信协议是...在这种情况下,查询不会被解析,不用生成执行计划,不会被执行。 查询优化处理 查询的生命周期的下一步是将一个SQL转换成一个执行接话,MySQL再按照这个执行计划和存储引擎进行交互。...查询执行引擎 在解析和优化阶段,MySQL将会生成查询对应的执行接话,MySQL的查询执行引擎则根据这个执行计划来完成整个查询。这里的执行计划是一个数据结构,而不是其他很多关系型数据库那样的字节码。...相对于查询优化阶段,查询执行阶段并不那么复杂:MySQL只是简单的根据执行计划给出的指令逐步执行。在根据执行计划逐步执行的过程中,有大量的操作需要通过调用存储引擎实现的接口来完成。
连接器连接流程 mysql -hip -Pport -uuser -p 是一个连接到 MySQL 服务器的命令,其中 ip 是要连接的 MySQL 服务器的主机名或 IP 地址,port 是 MySQL...执行计划描述了 MySQL 查询优化器将如何执行查询,包括使用哪些索引、连接方式、排序方式等。通过分析执行计划,可以确定查询的性能瓶颈和潜在优化点。...MySQL 优化器是一个智能的查询执行计划生成器,它会根据查询语句和表的信息,通过优化算法来选择最佳的查询执行策略。...执行器 什么是 MySQL 执行器 MySQL 执行器(MySQL Executor)是 MySQL 数据库的一个组件,负责执行查询语句并返回结果。...MySQL 执行器的主要功能包括: 查询解析和预处理:执行器首先对查询语句进行解析,识别查询类型、表名、列名等元素,并对其中的占位符进行替换。
本文将从MySQL总体架构--->查询执行流程--->语句执行顺序来探讨一下其中的知识。 一、MySQL架构总览: 架构最好看图,再配上必要的说明文字。 ...二、查询执行流程 下面再向前走一些,容我根据自己的认识说一下查询执行的流程是怎样的: 1.连接 1.1客户端发起一条Query请求,监听客户端的‘连接管理模块’接收请求 1.2...‘查询优化器’做大量的优化,生成执行计划 2.6模块收到请求后,通过‘访问控制模块’检查所连接的用户是否有访问目标表和目标字段的权限 2.7有则调用‘表管理模块’,先是查看table cache...ON,先连接后条件查询则用WHERE; mysql> SELECT -> * -> FROM -> table1 AS a -> LEFT OUTER JOIN table2...JOIN优化,JOIN子句里也优先从索引获取ID列表,然后直接关联查询获得最终结果 mysql> SELECT -> a.uid, -> count(b.oid) AS total
分组查询 1.1 语法 SELECT 字段列表 FROM 表名 [ WHERE 条件 ] GROUP BY 分组字段名 [ HAVING 分组后过滤条件 ]; 1.2 where与having区别 执行时机不同...1.3 注意事项: 分组之后,查询的字段一般为聚合函数和分组字段,查询其他字段无任何意义。 执行顺序: where > 聚合函数 > having 。...分页查询是数据库的方言,不同的数据库有不同的实现,MySQL中是LIMIT。 如果查询的是第一页数据,起始索引可以省略,直接简写为 limit 10。 3.3 案例: A....执行顺序 在讲解DQL语句的具体语法之前,我们已经讲解了DQL语句的完整语法,及编写顺序,接下来,我们要来说明的是DQL语句在执行时的执行顺序,也就是先执行那一部分,后执行那一部分。...from 先执行,然后执行 where , 再执行select 。
实际执行查询的顺序与书写顺序不同。...FROM 子句 执行顺序的第一步是确定数据来源。MySQL从指定的表中读取数据。这是查询的基础,其他所有操作都基于此数据集。 sql 复制代码 FROM table1 2....SELECT 子句 在经过前面的过滤和分组操作后,MySQL会执行SELECT子句,选择查询结果中需要返回的列。这时才会真正从数据集中挑选出我们想要的字段。...总结 理解MySQL查询语句的执行顺序有助于编写更高效的查询。通过合理安排各个子句,我们可以更好地控制查询的行为和性能。...希望这篇文章能帮助你更好地理解MySQL查询的执行过程,提高SQL查询优化的能力。
具体顺序 1.FROM 执行笛卡尔积 FROM 才是 SQL 语句执行的第一步,并非 SELECT 。对FROM子句中的前两个表执行笛卡尔积(交叉联接),生成虚拟表VT1,获取不同数据源的数据集。...FROM子句执行顺序为从后往前、从右到左,FROM 子句中写在最后的表(基础表 driving table)将被最先处理,即最后的表为驱动表,当FROM 子句中包含多个表的情况下,我们需要选择数据最少的表作为基础表...如果FROM子句包含两个以上的表,则对上一个联接生成的结果表和下一个表重复执行步骤1~3,直到处理完所有的表为止。 4.WHERE 应用WEHRE过滤器 对虚拟表 VT3应用WHERE筛选器。...因此使用 ORDER BY 子句查询不能应用于表达式。同时,ORDER BY子句的执行顺序为从左到右排序,是非常消耗资源的。
当希望MySQL能够以更高的性能运行查询时,最好的办法就是弄清楚MySQL是如何优化和执行查询的。一旦理解这一点,很多查询优化工作实际上就是遵循一些原则让优化器能够按照预想的合理的方式运行。...MySQL执行一个查询的过程。如图,我们可以看到当向MySQL发送一个请求的时候,MySQL到底做了些什么:图片1.客户端发送一条查询给服务器。...2.服务器先检查查询缓存,如果命中了缓存,则立刻返回存储在缓存中的结果。否则进入下一阶段。3.服务器端进行SQL解析、预处理,再由优化器生成对应的执行计划。4....MySQL根据优化器生成的执行计划,调用存储引擎的API来执行查询。5.将结果返回给客户端。
user表和user2表(内连接) 通过on后面的条件查询,user表中的age字段 等于 user2表中的age这个条件满足的话,才会把两个表中的数据都查询出来的,否则的话,查询数据就是空哦。...如下所示: image.png 六:node+mysql 多表联合查询 在mysql模块中,我们可以使用Connection对象的query方法的第一个参数编写sql语句来执行多表联合查询,但是如果在...where user.age = user2.age; 因此所有的代码如下所示: const mysql = require('mysql'); /* createConnection方法创建一个表示与...Mysql数据库服务器之间连接的 Connection对象 */ const connection = mysql.createConnection({ host: 'localhost', port...= require('mysql'); /* createConnection方法创建一个表示与Mysql数据库服务器之间连接的 Connection对象 */ const connection =
MySQL架构设计 下面是一张MySQL的架构图: ?...负责监听对 MySQL Server 的各种请求,接收连接请求,转发所有连接请求到线程管理模块。每一个连接上 MySQL Server 的客户端请求都会被分配(或创建)一个连接线程为其单独服务。...SQL语句执行流程 连接 客户端发来一条SQL语句,监听客户端的‘连接管理模块’接收请求 将请求转发到‘连接进/线程模块’ 调用‘用户模块’来进行授权检查 通过检查后,‘连接进/线程模块’从‘线程连接池...‘命令解析器’,经过词法分析,语法分析后生成解析树 接下来是预处理阶段,处理解析器无法解决的语义,检查权限等,生成新的解析树 再转交给对应的模块处理 如果是查询还会经由‘查询优化器’做大量的优化,生成执行计划...有则直接对应的表和获取锁,否则重新打开表文件 根据表的meta数据,获取表的存储引擎类型等信息,通过接口调用对应的存储引擎处理 上述过程中产生数据变化的时候,若打开日志功能,则会记录到相应二进制日志文件中 结果 SQL执行完成后
学习了极客时间MySql课程,做个总结 以一条select语句为例:select * from T where ID=4 ,梳理下执行的流程 一条sql语句在执行过程中需要经过连接器、分析器、优化器、...查询缓存 在经过连接器之后,会执行第二步查询缓存,在MySql拿到查询后,会先到查询缓存查看是否执行过这条语句,之前执行的结果会以key-value对的形式存在,如果不在查询缓存中,会继续执行后面的极端...在MySql8.0之后去掉了查询缓存的功能。...分析器 分析器会先做“词法分析”,识别出sql里的字符串分别是什么,读出“select”关键字对出这是一条查询语句,把字符串T识别成“表T” “语法分析”,根据词法分析的结果,判断该条sql是否满足MySql...的语法 优化器 优化器的作用在于选择最优的逻辑执行sql,例如在一个语句进行多表关联的时候,决定各个表的连接顺序 执行器 在开始执行前,先判断你对表T是否有执行查询的权限,没有就返回没有权限的错误,有权限则继续执行
领取专属 10元无门槛券
手把手带您无忧上云