首页 > 数据库 >【MySQL系列】--SQL 执行顺序

【MySQL系列】--SQL 执行顺序

时间:2024-04-05 20:55:54浏览次数:27  
标签:聚合 -- 子句 生成 虚拟 SQL MySQL 筛选 HAVING

不想往后翻直接告诉我结论,好的:)

  1. FROM:获取第一张表,称为原表table1,获取第二张表,称为原表table2,将两张表做笛卡尔积,生成第一张中间表Temp1。
    
  2. ON:根据筛选条件,在Temp1上筛选符合条件的记录,生成中间表Temp2。
    
  3. JOIN:根据连接方式的不同,选择是否在Temp2的基础上添加外部行。左外就把左表在Temp2中筛选掉的表添加回来生成Temp3,右外则是右表。
    
  4. WHERE:筛选表中的记录,对中间表temp3的记录进行过滤,生成temp4。
    
  5. GROUP BY:根据聚合键对表进行分组,即在temp4的基础上做分组,生成temp5。
    
  6. AGG_FUNC 计算聚合函数。
    
  7. WITH:应用cube或rollup生成超组,在Temp5的基础上添加超组,生成Temp6。
    
  8. HAVING:对组进行筛选,生成temp7。
    
  9. SELECT:选取字段,对temp7进行字段的选取,生成temp8。
    
  10. DISTINCT:对字段进行去重,对temp8进行去重,生成temp9。
    
  11. ORDER BY:按照排序键对表进行排序,对temp9中的表进行排序,生成temp10。
    
  12. LIMIT(TOP):对表进行分页,对temp10进行分页,生成temp11。
    


  1.    FROM 查询表数据,执行笛卡尔积
    

FROM 是 SQL 语句执行的第一步,from子句识别查询表的数据,对FROM子句中的前两个表执行笛卡尔积(交叉联接),生成虚拟表VT1,获取不同数据源的数据集。

  1.     ON 应用ON过滤器
    

对虚拟表VT1 应用ON筛选器,ON 中的逻辑表达式将应用到虚拟表 VT1中的各个行,筛选出满足ON 逻辑表达式的行,生成虚拟表 VT2 。

  1.      JOIN 添加外部行
    
  • 如果指定了OUTER JOIN保留表中未找到匹配的行将作为外部行添加到虚拟表 VT2,生成虚拟表 VT3。保留表如下:
  • LEFT OUTER JOIN把左表记为保留表(左连接)
  • RIGHT OUTER JOIN把右表记为保留表(右连接)
  • FULL OUTER JOIN把左右表都作为保留表(内连接)
  • 在虚拟表 VT2表的基础上添加保留表中被过滤条件过滤掉的数据,非保留表中的数据被赋予NULL值,最后生成虚拟表 VT3。
  • 如果FROM子句包含两个以上的表,则对上一个联接生成的结果表和下一个表重复执行步骤1~3,直到处理完所有的表为止。
  1.       WHERE 应用 WEHRE 过滤器
    

对虚拟表 VT3应用WHERE筛选器。根据指定条件对数据进行筛选,并把满足的数据插入虚拟表 VT4。

  1.       GROUP BY 分组
    

按GROUP BY子句中的列/列表将虚拟表 VT4中的行唯一的值组合成为一组,生成虚拟表VT5。如果应用了GROUP BY,非聚合字段必须出现在GROUP BY子句中或在聚合函数中使用。

  1.       AGG_FUNC 计算聚合函数
    

SQL Aggregate 计算聚合函数,函数计算从列中取得的值,返回一个单一的值。常用的 Aggregate 函数包涵以下几种:

  • AVG:返回平均值
    
  • COUNT:返回行数
    
  • FIRST:返回第一个记录的值
    
  • LAST:返回最后一个记录的值
    
  • MAX: 返回最大值
    
  • MIN:返回最小值
    
  • SUM: 返回总和
    
  1.      WITH 应用ROLLUP或CUBE
    

对虚拟表 VT5应用ROLLUP或CUBE选项,生成虚拟表 VT6。

  1.      HAVING 应用HAVING过滤器
    

对虚拟表VT6应用HAVING筛选器。根据指定的条件对数据进行筛选,并把满足的数据插入虚拟表VT7。

HAVING 中可以是普通条件的筛选,也能是聚合函数,HAVING 语句在SQL中的主要作用与WHERE语句作用是相同的,但是HAVING是过滤聚合值,在 SQL 中增加 HAVING 子句原因就是,WHERE 关键字无法与聚合函数一起使用,HAVING子句主要和GROUP BY子句配合使用。

  1.     SELECT 选出指定列
    

将虚拟表 VT7中的在SELECT中出现的列筛选出来,并对字段进行处理展示,计算SELECT子句中的表达式,产生虚拟表 VT8。

  1.    DISTINCT 行去重
    

将重复的行从虚拟表 VT8中移除,产生虚拟表 VT9。DISTINCT用来去除重复行,只保留唯一的。

  1.    ORDER BY 排序
    

执行order by 将数据按照一定顺序排序,将虚拟表 VT9中的行按ORDER BY 子句中的列/列表排序,生成游标 VC10 ,注意不是虚拟表。因此使用 ORDER BY 子句查询不能应用于表达式。同时,ORDER BY子句的执行顺序为从左到右排序,是非常消耗资源的。执行order by 将数据按照一定顺序排序.

  1.    LIMIT/OFFSET 指定返回行
    

从VC10的开始处选择指定数量行,生成虚拟表 VT11,并返回调用者。

标签:聚合,--,子句,生成,虚拟,SQL,MySQL,筛选,HAVING
From: https://www.cnblogs.com/o-O-oO/p/18116169

相关文章

  • P9902 『PG2』模拟最大流 题解
    首先最大流等于最小割,然后就能很容易地想到一个状压dp做法:记\(f_{i,s}\)表示使得前\(i\)个点中,最后\(k\)个点与点\(1\)的联通情况为\(s\)的最小代价。然后考虑下一个点是否联通直接转移即可,然后就做完了。时间复杂度\(\mathcalO(n2^k)\)。参考代码:#include<bits/s......
  • 2024.2.25 模拟赛
    A按题意直接模拟即可。也就是每次取出一些字符,放入字符串\(P\)中。注意实现时的时间复杂度,不要写成\(O(n^2)\)的。#include<bits/stdc++.h>usingnamespacestd;chars[1000010],t[1000010];inthd1=1,hd2=1,n,m,x,y;charans[2000010];intmain(){ scanf("%s",s+1);n......
  • 7.列表
    #列表#删除列表中的元素listvar=['google','taobao','jingdong','pinduoduo']dellistvar[0]print(listvar)#['taobao','jingdong','pinduoduo']#列表比较#operator的eq模块:比较两个列表是否相同,相同返回True,......
  • 2-36. 时间系统 UI 制作
    添加GameTime然后增加一个黑色的圆Day&Night再增加一个表示时间的图片给Day&Night添加遮罩Mask添加Clock这里每个格子表示一个小时,6个小时之后就要切换另一个图片添加GameDate添加Time添加GameSeason添加暂停按钮项目相关代码代码仓库:https://g......
  • 导入模块
    1初始化模块模块包含可执行语句及函数定义。这些语句用于初始化模块,且仅在import语句第一次遇到模块名时执行 2为了保证运行效率,每次解释器会话只导入一次模块。如果更改了模块内容,必须重启解释器;仅交互测试一个模块时,也可以使用importlib.reload(),例如importimportli......
  • 导入项目运行后,报错java: Cannot find JDK ‘XX‘ for module ‘XX‘
    解决方案:1、删除.idea和.iml文件2、右击此module,点击OpenModuleSettings在ModuleSDK中选择所安装的java版本后,点击右下角Apply3、再运行试试吧,成功!......
  • tomcat 8.5 本地编译代码
    1、下载地址:https://tomcat.apache.org/download-80.cgi 2运行1)解压zip压缩包2)目录创建进入解压目录,并创建一个目录,命名为home,并将conf、webapps目录移入home目录中3)修改成maven项目在当前目录下创建一个pom.xml文件,引入tomcat的依赖包,改造成maven项目,pom文件......
  • 微信小程序开发 基础知识(持续更新中~)
    ......
  • 基于springboot的厨艺交流平台,美食交流管理系统,附源码+数据库+论文,包远程安装调试
    1、项目介绍这次开发的厨艺交流平台功能有个人中心,食材分类管理,用户管理,菜品分类管理,菜谱信息管理,食材信息管理,商品分类管理,商品信息管理,美食日志管理,健康文章管理,系统管理,订单管理等。经过前面自己查阅的网络知识,加上自己在学校课堂上学习的知识,决定开发系统选择B/S模式这种......
  • 成都集训的若干件小事
    扑克死了,这没准挺坏的。其实我一直有一个想喝劲凉冰红茶的愿望。这个愿望只在4.3被满足了。找到了戴上和摘下牙套的最佳时间。开心开心。晨练到4.2,然后就一直在下雨了。对某天晚上的自己感到很力不从心,觉得自己没准改变不了什么过去。颈椎会很痛的说。不知道接下来的几天......