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

mysql查询语句执行顺序

Mysql SQL查询处理顺序: (8)select (9)distinct (1)from (3) join <right_table...from,最后执行是limit,每个操作都会产生一个虚拟表,做为下一步输入,这个虚拟表对用户是透明,只有最后一个虚拟表才会返回给用户 (1)from 对和执行笛卡尔积,产生虚拟表VT1 (2)on 对VT1应用on条件过滤,把符合记录放入VT2 (3)join 如果指定了join类型,如 left join、right...join,把相应外部行添加到VT2,形成VT3 如果from中有两个以上表,使用VT3和下一个表再执行一遍前3步,直到处理完所有的表 (4)where 对VT3应用where过滤,把符合<where_condition...对VT8进行去重操作,产生VT9 (10)order by 根据对VT9进行排序,产生VT10 (11)limit 取出指定行记录,产生VT11,返回给用户

5.1K50

Mysql资料 查询SQL执行顺序

具体顺序 1.FROM 执行笛卡尔积 FROM 才是 SQL 语句执行第一步,并非 SELECT 。对FROM子句中前两个表执行笛卡尔积(交叉联接),生成虚拟表VT1,获取不同数据源数据集。...FROM子句执行顺序为从后往前、从右到左,FROM 子句中写在最后表(基础表 driving table)将被最先处理,即最后表为驱动表,当FROM 子句中包含多个表情况下,我们需要选择数据最少表作为基础表...如果FROM子句包含两个以上表,则对上一个联接生成结果表和下一个表重复执行步骤1~3,直到处理完所有的表为止。 4.WHERE 应用WEHRE过滤器 对虚拟表 VT3应用WHERE筛选器。...11.ORDER BY 排列 将虚拟表 VT9中行按ORDER BY 子句中列/列表排序,生成游标 VC10 ,注意不是虚拟表。因此使用 ORDER BY 子句查询不能应用于表达式。...同时,ORDER BY子句执行顺序为从左到右排序,是非常消耗资源。 12.LIMIT/OFFSET 指定返回行 从VC10开始处选择指定数量行,生成虚拟表 VT11,并返回调用者。

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

MySQL】:分组查询、排序查询、分页查询、以及执行顺序

本文将深入探讨DQL分组查询、排序查询和分页查询等常见操作,为读者提供全面的DQL查询知识。 一....1.3 注意事项: 分组之后,查询字段一般为聚合函数和分组字段,查询其他字段无任何意义。 执行顺序: where > 聚合函数 > having 。...分页查询是数据库方言,不同数据库有不同实现,MySQL中是LIMIT。 如果查询是第一页数据,起始索引可以省略,直接简写为 limit 10。 3.3 案例: A....执行顺序 在讲解DQL语句具体语法之前,我们已经讲解了DQL语句完整语法,及编写顺序,接下来,我们要来说明是DQL语句在执行执行顺序,也就是先执行那一部分,后执行那一部分。...综上所述,我们可以看到DQL语句执行顺序为: from … where … group by …having … select … order by … limit … ️全篇总结 本文详细介绍了DQL

27610

MySQL语句执行顺序

MySQL语句一共分为11步,如下图所标注那样,最先执行总是 FROM操作,最后执行是LIMIT操作。...其中每一个操作都会产生一张虚拟表,这个虚拟表作为一个处理输入,只是这些虚拟表对用户来说是透明 ,但是只有最后一个虚拟表才会被作为结果返回。...如果没有在语句中指定某一个子句,那么将会跳过相应步骤。 ? 下面我们来具体分析一下查询处理每一个阶段 FORM: 对FROM左边表和右边表计算笛卡尔积。...,那么就会对上一个join连接产生结果VT3和下一个表重复执行步骤1~3这三个步骤,一直到处理完所有的表为 止。...SELECT: 执行select操作,选择指定列,插入到虚拟表VT8中。 DISTINCT: 对VT8中记录进行去重。产生虚拟表VT9.

6.4K100

MySQLsql执行顺序

在SQL语句中每个关键字都会按照顺序往下执行,而每一步操作,会生成一个虚拟表,最后产生虚拟表会作为执行最终结果返回。下面的是常用关键字执行顺序: ?...)未匹配行作为外部行添加到虚拟表VT2中,从而产生虚拟表VT3; 4、WHERE:对虚拟表VT3进行WHERE条件过滤,只有符合记录才会被放入到虚拟表VT4; 5、...:对虚拟表VT6进行HAVING条件过滤,只有符合记录才会被插入到虚拟表VT7中; 8、SELECT:执行SELECT操作,选择指定列,插入到虚拟表VT8中; 9...、DISTINCT:对虚拟表VT8中记录进行去重,产生虚拟表VT9; 10、ORDER BY:将虚拟表VT9中记录按照进行排序操作,产生虚拟表VT10; 11、LIMIT...:取出指定行记录,产生虚拟表VT11,并将结果返回。

2.2K20

步步深入:MySQL 架构总览->查询执行流程->SQL 解析顺序

一直是想知道一条 SQL 语句是怎么被执行,它执行顺序是怎样,然后查看总结各方资料,就有了下面这一篇博文了。...本文将从 MySQL 总体架构 -> 查询执行流程 -> 语句执行顺序来探讨一下其中知识。 MySQL 架构总览 架构最好看图,再配上必要说明文字。...查询执行流程 下面再向前走一些,容我根据自己认识说一下查询执行流程是怎样: 连接 客户端发起一条 Query 请求,监听客户端连接管理模块接收请求; 将请求转发到连接进/线程模块; 调用用户模块来进行授权检查...,检查权限等,生成新解析树; 再转交给对应模块处理; 如果是 SELECT 查询还会经由‘查询优化器’做大量优化,生成执行计划; 模块收到请求后,通过访问控制模块检查所连接用户是否有访问目标表和目标字段权限...group_by_list > HAVING ORDER BY LIMIT 然而它执行顺序是这样

1.2K30

SQL查询执行顺序解析

介绍 分享这篇文章是因为在SQL JOIN,你想知道应该都有这篇文章中有个小伙伴问我,ON和WEHRE执行顺序是怎样,并且SQL执行顺序在面试中也经常被问,所以把姜承尧大佬《MySQL技术内幕...SQL编程》中关于SQL执行顺序部分简单概述了一下,并配上例子,有想深入了解可以去看书 SQL语言不同于其他编程语言(如C++,Java),最明显不同体现在处理代码顺序上。...但在SQL语言中,第一个被处理子句总数FROM子句,下面显示了逻辑查询处理顺序以及步骤序号 (8)SELECT (9)DISTINCT (1)FROM <left_table...我们来具体分析查询处理各个阶段 FROM:对FROM子句中左表和右表执行笛卡尔积,产生虚拟表VT1 ON:对虚拟表VT1应用ON筛选,只有那些符合<...2 应用ON过滤器 SELECT查询一共有3个过滤过程,分别是ON,WHERE,HAVING。ON是最先执行过滤过程。

1.4K32

MySQL执行过程以及顺序

因为学习和了解MySQL是至关重要,那么当我们在客户端发起一个sql到出现详细查询数据,这其中究竟经历了什么样过程?MySQL服务端是如何处理请求,又是如何执行sql语句?...本篇博客将来探讨这个问题: 本篇博客目录 一:MySQL执行过程 二:MySQL执行过程中状态 三:MySQL执行顺序 四:总结 一:MySQL执行过程 MySQL整体执行过程如下图所示: 1.1...,会在MySQL自带权限表中查询当前用户权限: MySQL中存在4个控制权限表,分别为user表,db表,tables_priv表,columns_priv表,MySQL权限表验证过程为: 1:...囊括了所有的MySQL所有状态,其中具体含义如下图: 三:sql执行顺序 事实上,sql并不是按照我们书写顺序来从前往后、左往右依次执行,它是按照固定顺序解析,主要作用就是从上一个阶段执行返回结果来提供给下一阶段使用...筛选出找到数据集 四:总结 本篇博客总结了MySQL执行过程,以及sql执行顺序,理解这些有助于我们对sql语句进行优化,以及明白MySQLsql语句从写出来到最终执行轨迹,有助于我们对sql

1.3K20

Mysql-SQL执行顺序

SQL执行顺序事实上,sql并不是按照我们书写顺序来从前往后、左往右依次执行,它是按照固定顺序解析,主要作用就是从上一个阶段执行返回结果来提供给下一阶段使用,sql在执行过程中会有不同临时中间表...通过from 和 join on 选择出需要执行数据库表T和S,产生笛卡尔积,生成T和S合并临时中间表Temp1。...按照固定字段进行分组,产生临时中间表Temp4, "这个过程只是数据顺序发生改变,而数据总量不会变化,表中数据以组形式存在" 实例说明:在temp3表数据中对mobile...by 分组语句后,否则语法会编译不通过) 对分组聚合完表挑选出需要查询数据,如果为*会解析为所有数据,此时会产生中间表Temp6 实例说明:在此阶段就是对temp5临时聚合表中含有...实例说明:在temp7中排好序数据,然后取前五条插入到Temp9这个临时表中,最终返回给客户端ps:实际上这个过程也并不是绝对这样,中间mysql会有部分优化以达到最佳优化效果,比如在select

16010

MySQL 查询执行过程

查询生命周期大致可以按照顺序来看:从客户端到服务端,然后在服务器上进行解析,生成执行计划,执行,并返回结果给客户端。...当希望 MySQL 能够以高性能方式运行查询时,最好办法就是弄清楚 MySQL 是如何优化和执行查询MySQL 执行一个查询过程,如下: ?...MySQL 解析器使用 MySQL 语法规则验证和解析查询。例如验证是否使用错误关键字,或者使用关键字顺序是否正确等,还会验证引号前后是否正确等。...或者在一个语句有多表关联(join)时候,决定各个表连接顺序; 优化器:将语法树转化成执行计划。一条查询可以有多种执行方式,最终都返回相同结果。优化器作用就是找到其中最好执行计划。...下面是一些 MySQL 能够处理优化类型: 【1】重新定义关联表顺序:数据表关联并不总是按照在查询中指定顺序进行。决定关联顺序是优化器很重要一部分功能。

2.2K30

MySQL查询执行过程

mySQL查询执行过程 01 查询流程图 当我们希望MySQL能够以更高性能进行查询时,弄清楚MySQL中是如何优化和执行查询就显得很有必要,这里,先搬出来一张图镇楼: ?...这张图写清楚了一个查询MySQL执行过程: 1、客户端发送一条查询给服务器。 2、服务器先检查查询缓存,如果命中了缓存,则会进行权限校验,权限校验通过,直接返回结果。...3、如果没有命中缓存,则进行SQL解析、预处理、再由优化器进行查询优化,计算各项查询方法成本、生成对应执行计划。 4、MySQL根据执行计划,调用存储引擎API来执行查询。...04 查询优化处理 查询优化处理包含多个部分,例如解析SQL、预处理、优化SQL执行计划等等,其中: 语法解析器是专门解析MySQL语法,一旦发现错误关键字、数据类型、关键字顺序、字段和数值顺序等等...,它工作包括但不限于子查询优化、提前终止查询、预估数据并转化为常数表达式、冲新定义关联表顺序、使用等价变换规则等等。

2K10

【0基础学习mysql】之DQL-分页查询执行顺序

CSDN话题挑战赛第2期 参赛话题:学习笔记 学习之路,长路漫漫,写学习笔记过程就是把知识讲给自己听过程。这个过程中,我们去记录思考过程,便于日后复习,梳理自己思路。...目录 一、分页查询 1.语法 2.实例 二、DQL执行顺序 1.顺序 2.实例 小结 1、基本查询 1.查询多个字段 2.查询所有字段 3.设置别名 4.去除重复查询 2.条件查询 3.聚合函数 4....',65),(7,'老叶',65),(8,'老高',65),(9,'老黄',65),(10,'老胡',65),(11,'老冯',65); SELECT * FROM user LIMIT 10; 3.执行结果...二、DQL执行顺序 1.顺序 1.FROM          表名列表 2.WHERE         条件列表 3.GROUP BY         分组字段列表 4.HAVING         ...FROM 表名;(AS可省略,[]在这里只是用于区分,输入代码时没[]) 4.去除重复查询 SELECT DISTINCT 字段列表 FROM 表名; 2.条件查询 SELECT 字段列表

39840

MySQL查询执行基础

当我们希望MySQL能够以更高性能运行查询时,最好办法就是弄清楚MySQL是如何优化和执行查询。...服务器端进行SQL解析、预处理,再由优化器生成对应执行计划 MySQL根据优化器生成执行计划,调用存储引擎API来执行查询 将结果返回客户端 MySQL客户端/服务器通信协议 MySQL客户端和服务器之间通信协议是...在这种情况下,查询不会被解析,不用生成执行计划,不会被执行查询优化处理 查询生命周期下一步是将一个SQL转换成一个执行接话,MySQL再按照这个执行计划和存储引擎进行交互。...查询执行引擎 在解析和优化阶段,MySQL将会生成查询对应执行接话,MySQL查询执行引擎则根据这个执行计划来完成整个查询。这里执行计划是一个数据结构,而不是其他很多关系型数据库那样字节码。...相对于查询优化阶段,查询执行阶段并不那么复杂:MySQL只是简单根据执行计划给出指令逐步执行。在根据执行计划逐步执行过程中,有大量操作需要通过调用存储引擎实现接口来完成。

1.3K00
领券