数据库-做题整理

1.SQL执行顺序

第一步:加载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中筛选列(即select,生成vt8

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

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

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

 

2.排序: order by

3.Limit

4.select

5.GROUP BY

6.如果想给数据进行排序,并得到名次的话,可以把数据列做成相同两份ab,用a>=b,意思是当前a值下,有多少个b值小于a值,再countb)值就可以得到当前a值大小排第几,别忘了对a进行group by,要不然会对全部b进行count

posted @ 2020-03-25 16:55  BeeeenWei  阅读(158)  评论(0)    收藏  举报