• MySql学习笔记(二):SQL执行顺序


    一、手写SQL顺序

    select <select_list>
    from <table_name>
    <join_type> join <join_table> on <join_condition>
    where <where_condition>
    group by <group_by_list>
    having <having_condition>
    order by <order_by_condition>
    limit <limt_number>

    二、MySql执行顺序

    from <left table>
    on <on_condition>
    <join_type> join <join_table>
    where <where_condition>
    group by <group_by_list>
    <sum()avg()等聚合函数>
    having <having_condition>
    select <select_list>
    distinct
    order by <order_by_condition>
    limit <limit_number>

    三、MySql执行顺序理解

    第一步:加载from子句的前两个表计算笛卡尔积,生成虚拟表vt1;

    第二步:筛选关联表符合on表达式的数据,保留主表,生成虚拟表vt2;

    第三步:如果使用的是外连接,执行on的时候,会将主表中不符合on条件的数据也加载进来,做为外部行

    第四步:如果from子句中的表数量大于2,则重复第一步到第三步,直至所有的表都加载完毕,更新vt3;

    第五步:执行where表达式,筛选掉不符合条件的数据生成vt4;

    第六步:执行group by子句。group by 子句执行过后,会对子句组合成唯一值并且对每个唯一值只包含一行,生成vt5,。一旦执行group by,后面的所有步骤只能得到vt5中的列(group by的子句包含的列)和聚合函数。

    第七步:执行聚合函数,生成vt6;

    第八步:执行having表达式,筛选vt6中的数据。having是唯一一个在分组后的条件筛选,生成vt7;

    第九步:从vt7中筛选列,生成vt8;

    第十步:执行distinct,对vt8去重,生成vt9。其实执行过group by后就没必要再去执行distinct,因为分组后,每组只会有一条数据,并且每条数据都不相同。

    第十一步:对vt9进行排序,此处返回的不是一个虚拟表,而是一个游标,记录了数据的排序顺序,此处可以使用别名;

    第十二步:执行limit语句,将结果返回给客户端

    备注1:

    1、on和where的区别?

    简单地说,当有外关联表时,on主要是针对外关联表进行筛选,主表保留,当没有关联表时,二者作用相同。

    例如在左外连时,首先执行on,筛选掉外连表中不符合on表达式的数据,而where的筛选是对主表的筛选。

    转载自:https://blog.51cto.com/13593129/2357192

  • 相关阅读:
    Windows系统Nessus离线(Offline) 版的安装
    Openstack中keystone与外部LDAP Server的集成
    MySQL常用指令
    关于RequestParam在不同的Spring版本上,接口在controller重载时注解可能失效的踩坑记录
    利用反射注册SpringCache的RedisCacheManager缓存信息
    缩减项目代码中的大面积if策略
    Pentaho Report Designer 报表系统
    五种设计模式的分享
    反射的实践测试
    关于内外网分离情况下双网卡访问速度问题的解决
  • 原文地址:https://www.cnblogs.com/jinliang374003909/p/12895519.html
Copyright © 2020-2023  润新知