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

MySQL执行SQL语句过程详解

开发人员基本都知道,我们的数据存在数据库中(目前最多的是MySQL和Oracle,由于作者更擅长MySQL,所以这里默认数据库为MySQL),服务器通过sql语句将查询数据的请求传入到MySQL数据库。...流程概述   MySQL得到sql语句后,大概流程如下:   1.sql的解析器:负责解析和转发sql   2.预处理器:对解析后的sql树进行验证   3.查询优化器:得到一个执行计划   4.查询执行引擎...成本指的是MySQL根据相关的统计信息,算出来sql语句对应的io,cpu等的消耗的一个估计值。计算过程涉及到索引、表、行等数据,过程比较复杂。   ...1.查询优化器使用统计信息为sql选择执行计划。   2.MySQL没有数据直方图,也无法手工删除统计信息。(oracle有)   3.在服务器曾有查询优化器,却没有保存数据和索引统计信息。...+返回数据给客户端   得到执行计划后,根据已有的执行计划,查询执行引擎,MySQLSQL Layer层,调用Storage Engine Layer层的接口,从MySQL的存储引擎中获取到相对应的结果集

3.4K20

MySqlsql语句执行过程详述

前言: 很多人都在使用mysql数据库,但是很少有人能够说出来整个sql语句的执行过程是怎样的,如果不了解执行过程的话,就很难进行sql语句的优化处理,也很难设计出来优良的数据库表结构。...这篇文章主要是讲解一下sql语句的执行过程sql语句的执行过程: 客户端、连接器、分析器、优化器、执行器、存储引擎几个阶段。 连接器的作用:管理链接、权限验证的处理。...最常用的是InnoDB,这个主要在Mysql5.5版本开始成为了默认存储引擎。 当在执行sql查询的时候,如果不指定引擎类型、默认使用的innoDB。...分析器: 分析器首先会进行词法分析,输入的是由多个字符串和空格组成的一条sql语句,mysql需要识别出来里面的字符串分别是什么,代表什么意思。...然后进行语法分析的处理,根据词法分析,根据词法分析的结果,语句分析器就会根据语法规则判断输入的这个sql语句是否满足mysql的语法。

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

MySQL探秘(二):SQL语句执行过程详解

昔日庖丁解牛,未见全牛,所赖者是其对牛内部骨架结构的了解,对于MySQL亦是如此,只有更加全面地了解SQL语句执行的每个过程,才能更好的进行SQL的设计和优化。  ...服务器端进行SQL解析、预处理,再由优化器生成对应的执行计划。 MySQL根据优化器生成的执行计划,再调用存储引擎的API来执行查询。 将结果返回给客户端。...SQL语句执行过程 查询缓存  MySQL查询缓存保存查询返回的完整结构。当查询命中该缓存时,MySQL会立刻返回结果,跳过了解析、优化和执行阶段。  ...查询缓存系统会跟踪查询中涉及的每个表,如果这些表发生了变化,那么和这个表相关的所有缓存数据都将失效。  ...如果在一条SQL语句执行过程中将该语句对应的最终执行计划进行缓存,当相似的语句再次被输入服务器时,就可以直接使用已缓存的执行计划,从而跳过SQL语句生成执行计划的整个过程,进而可以提高语句的执行速度。

1.8K30

MySQL探秘(二):SQL语句执行过程详解

昔日庖丁解牛,未见全牛,所赖者是其对牛内部骨架结构的了解,对于MySQL亦是如此,只有更加全面地了解SQL语句执行的每个过程,才能更好的进行SQL的设计和优化。  ...服务器端进行SQL解析、预处理,再由优化器生成对应的执行计划。 MySQL根据优化器生成的执行计划,再调用存储引擎的API来执行查询。 将结果返回给客户端。...SQL语句执行过程 查询缓存  MySQL查询缓存保存查询返回的完整结构。当查询命中该缓存时,MySQL会立刻返回结果,跳过了解析、优化和执行阶段。  ...查询缓存系统会跟踪查询中涉及的每个表,如果这些表发生了变化,那么和这个表相关的所有缓存数据都将失效。  ...如果在一条SQL语句执行过程中将该语句对应的最终执行计划进行缓存,当相似的语句再次被输入服务器时,就可以直接使用已缓存的执行计划,从而跳过SQL语句生成执行计划的整个过程,进而可以提高语句的执行速度。

5.2K10

mysql存储过程执行_mysql存储过程执行

EVENT if not exists e_test on schedule every 30 second on completion preserve do call test(); 每隔30秒将执行存储过程...实战mysql存储程序与定时器 存储过程定时器eventprocedure实战 需求:一个庞大的日志表,现每天做定时统计一天的总数,放另一个表中,方便查看,运营。...旧方案:用脚本写好程序,用linux的crontab定时执行。 本文重点,用mysql定时器定时执行存储程序。...执行这个语句之前要先 Sql代码 delimiter $$ 执行完成后再 Sql代码 delimiter ; 用show查看是否已经成功 Sql代码 show procedure status like...‘%%’; 第二步:开启mysql定时器 如果不是on,就执行 Sql代码 set global event_scheduler=1; 不需要重启mysql 会发现mysql多起了一个daemon进程

16.6K20

SQLMysql中一条sql语句的执行过程

通过这张图,我们可以直观的看到MySQL的内部结构,包括连接器、缓存、解析器、优化器、存储引擎以及支持DDL、DML、存储过程、视图等功能的SQL接口。...接下来,通过一条sql语句的执行来深入了解MySQL各个组件功能以及其作用。...一、SQL语句的执行流程 1、连接MySQL 通常我们会编写sql语句通过某个客户端来执行并且接受执行结果,比如命令行、JDBC、navicat。...SQL解析报错 而像 select id from table1 这条sql语句会被解析成下图: 解析树 如果想了解具体的解析过程可以参考这篇博客 4、优化SQL语句 通过解析器生成sql语法树后就到了...这个就要依赖于 MySQL 的处理机制了,MySQL 的处理过程如下: 判断 redo log 是否完整,如果判断是完整的,就立即提交。

22410

MySQL:一条SQL语句的执行过程

MYSQL8版本直接将查询缓存的整块功能删掉了。 第三步:分析器 分析器首先会做“词法分析”,MYSQL会识别出SQL语句里面的字符串是什么以及代表什么。...接下来就是“语法分析器”,分析SQL的语法问题。 第四步:优化器 优化器会对SQL执行顺序,使用哪个索引进行优化。确定SQL执行方案。...第五步:执行执行执行SQL语句会对权限进行校验,如果有权限,就打开表继续执行。打开表的时候,执行器就会根据表的引擎定义,去使用这个引擎提供的接口。...图片 一条update语句执行流程 update语句除了会执行上面的五步,还会涉及两个重要的日志模块。...然后告知执行执行完成了,随时可以提交事务了。 执行器生成这个操作的binlog,并把binlog写入磁盘。

18820

Mysql执行过程

Mysql 执行流程 大致流程描述: MySQL客户端通过协议将SQL语句发送给MySQL服务器。...之所以删除掉,是因为要求SQL和参数都是一样,同时查询缓存系统会跟踪查询中涉及的每一个表,如果这些表发生变化,则该表相关的所有缓存数据均会失效,查询缓存的失效非常频繁, 如果在一个写多读少的环境中,缓存会频繁的新增和失效...查询优化器 能够进入到优化器阶段表示sql是符合mysql的标准语义规则的并且可以执行的,此阶段主要是进行sql语句的优化,会根据执行计划进行最优的选择,匹配合适的索引,选择最佳的执行方案。...,同时在这个阶段是自动按照执行计划进行预处理,mysql会计算各个执行方法的最佳时间,最终确定一条执行sql交给最后的执行器 查询优化器是整个流程中重要的一环。...如果在一条SQL语句执行过程中将该语句对应的最终执行计划进行缓存,当相似的语句再次被输入服务器时,就可以直接使用已缓存的执行计划,从而跳过SQL语句生成执行计划的整个过程,进而可以提高语句的执行速度。

2.8K20

SQL联表细节,MySQL JOIN 的执行过程

问题背景   对于 MySQL 的 JOIN,不知道大家有没有去想过他的执行流程,亦或有没有怀疑过自己的理解(自信满满的自我认为!)...多表连接的顺序     假设我们有 3 张表:A、B、C,和如下 SQL -- 伪 SQL,不能直接执行 A LEFT JOIN B ON B.aId = A.id LEFT JOIN C ON C.aId...多表连接查询的执行细节(一)   SQL 执行的流程图     当我们向 MySQL 发送一个请求的时候,MySQL 到底做了些了什么 ?...SQL 执行路径,摘自《高性能MySQL》     可以看到,执行计划是查询优化器的输出结果,执行引擎根据执行计划来查询数据   数据准备     MySQL 5.7.1,InnoDB 引擎;建表 SQL...View Code   单表查询     单表查询的过程比较好理解,大致如下 ?

4.8K10

MySQL数据库:SQL语句的执行过程

一、客户端的MySQL驱动: 我们的系统在和 MySQL 数据库进行通信前,需要先和数据库建立连接,而这个功能就是由MySQL驱动底层帮我们完成的,建立完连接之后,我们只需要发送 SQL 语句就可以执行...在优化过程中,经过的一系列运算是什么呢?...;只要是统计分析出来的,那就可能会存在分析错误的情况,所以在SQL执行不走索引时,也要考虑到这方面的因素 MySql执行计划怎么查看呢?...在执行SQL语句前添加上 explain 关键字即可; 5、执行器: MySQL 通过分析器知道了你要做什么,通过优化器知道了该怎么做,于是就进入了执行器阶段,开始执行语句。...key是SQL语句,value是查询结果。我们将这个过程称为查询缓存! (2)Buffer Pool位于存储引擎层。

3.5K10

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

73840

MySQL 有效利用 profile 分析 SQL 语句的执行过程

在日常的工作中,我们通常要分析 SQL 语句的性能,通过会使用到执行计划,利用执行计划来分析 SQL 语句的性能,并进行相应的优化;本文将利用 profile 分析 SQL 语句的执行过程来辅助的分析...SQL 语句,做好优化; 分析 SQL 执行带来的开销是优化 SQL 的重要手段。...该参数开启后,后续执行SQL 语句都将记录其资源开销,诸如 IO,上下文切换,CPU,Memory 等等。根据这些开销进一步分析当前 SQL 瓶颈从而进行优化与调整。...本文描述了如何使用 MySQL profile 以及利用 Performance_Schema 来查询 profile 的 SQL 执行过程的样例; 一、有关 profile 的描述 1、查看 profiling...query end:表示语句执行完毕了,但是还有一些后续工作没做完时的状态。

4.1K31

SQL语句执行过程详解

3、分析器 4、优化器 5、执行器 Server层 存储引擎(InnoDB)层 三个日志的比较(undo、redo、bin) 执行过程 Where 条件的提取 SQL执行顺序 写操作 读操作 文章正文:...写操作执行过程   如果这条sql是写操作(insert、update、delete),那么大致的过程如下,其中引擎层是属于 InnoDB 存储引擎的,因为InnoDB 是默认的存储引擎,也是主流的,...,mysql会计算各个执行方法的最佳时间,最终确定一条执行sql交给最后的执行器。...记录修改的 sql。缺点是在 mysql 集群时可能会导致操作不一致从而使得数据不一致(比如在操作中加入了Now()函数,主从数据库操作的时间不同结果也不同)。优点是占空间小,执行快。...执行过程 写操作 通过上面的分析,可以很容易地了解开始的更新执行图。这里就不过多阐述了。

2.3K30

SQL语句执行过程详解

一条sql,plsql的执行到底是怎样执行的呢?...一、SQL语句执行原理: 第一步:客户端把语句发给服务器端执行 当我们在客户端执行 select 语句时,客户端会把这条 SQL 语句发送给服务器端,让服务器端的 进程来处理这语句。...二是绝大部分 SQL 语句都是按照这个处理过程处理的。我们 DBA 或者基于 Oracle 数据库的开发人员了解这些语句的处理过程,对于我们进行涉及到 SQL 语句的开发与调试,是非常有帮助的。...DBCC FREEPROCCACHE 从过程缓存中删除所有元素。 DBCC FREESYSTEMCACHE 从所有缓存中释放所有未使用的缓存条目 SQL语句中的函数、关键字、排序等执行顺序: 1....二、SQL语句执行完整过程: 1.用户进程提交一个 sql 语句: update temp set a=a*2,给服务器进程。

3.9K60

新特性解读 | MySQL 8.0:explain analyze 分析 SQL 执行过程

介绍 MySQL 8.0.16 引入一个实验特性:explain format=tree ,树状的输出执行过程,以及预估成本和预估返回行数。...在 MySQL 8.0.18 又引入了 EXPLAIN ANALYZE,在 format=tree 基础上,使用时,会执行 SQL ,并输出迭代器(感觉这里用“算子”更容易理解)相关的实际信息,比如执行成本...文档链接:https://dev.mysql.com/doc/refman/8.0/en/explain.html#explain-analyze 示例: mysql> explain format=tree...,展示了比较清晰的执行过程。...阅读顺序 从右到左:没有遇到并列的迭代器之前,都是从右边开始执行; 从上到下:遇到并列的迭代器,都是上边的先开始执行 上述示例阅读顺序如下图(注意最好不要\G输出,否则第一行的缩进不准确),SQL执行顺序为

2.1K42

浅谈SQL语句的执行过程

写在前面的话:有时不理解SQL语句各个部分执行顺序,导致理解上出现偏差,或者是书写SQL语句时随心所欲,所以有必要了解一下sql语句的执行顺序。可以有时间自己写一个简单的数据库,理解会更加深入。...没错,对于这样的简单的语句,一眼就能看出来,可是对于稍微复杂一些的SQL语句或者更加复杂的SQL语句,有时我们一眼就看不出来了,为了能够正确分析SQL语句以及写出正确的SQL语句,有必要了解一下SQL语句各部分的执行顺序...语句的执行顺序,Table1和Table2如下: ?...Table1        Table2 下面先给出上面的SQL语句的执行顺序,然后进行讲解: (8)  select (9)  distinct (11)  top 1 (6)  Table1....经过上面的过程,最终的SQL语句将VT10返回给用户使用。 所以以后再写SQL语句的时候,可以按照上面的顺序写SQL语句了,读SQL语句也可以按照上面的顺序去读,做到心里明白。

1.4K20
领券