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

1、手写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>

2、MySql执行顺序ide

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>

3、MySql执行顺序理解
函数

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

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

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

第四步:若是from子句中的表数量大于2,则重复第一步到第三步,直至全部的表都加载完毕,更新vt3;io

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

第六步:执行group by子句。group by 子句执行事后,会对子句组合成惟一值而且对每一个惟一值只包含一行,生成vt5,。一旦执行group by,后面的全部步骤只能获得vt5中的列(group by的子句包含的列)和聚合函数。class

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

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

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

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

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

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

4、其余

一、on和where的区别?

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

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

二、图解

image.png

相关文章
相关标签/搜索