容易被忽略的事----sql语句中select语句的执行顺序

    关于Sql中Select语句的执行顺序,一直很少注意这个问题,对于关键字的使用也很随意,至于效率问题,因为表中的数据量都不是很大,所以也不是很在意。

    今天在一次面试的时候自己见到了,感觉没一点的印象,所以也就没有答上来,现在整理一下吧,希望提醒自己,也能够帮到其他的朋友。如下:

(8)   SELECT (9)DISTINCT 
(11) <TOP_specification> <select_list> 
(1)   FROM <left_table> 
(3)   <join_type> JOIN <right_table> 
(2)   ON <join_condition> 
(4)   WHERE <where_condition> 
(5)   GROUP BY <group_by_list> 
(6)   WITH {CUBE | ROLLUP} 
(7)   HAVING <having_condition> 
(10) ORDER BY <order_by_list>

    每个步骤产生一个虚拟表,该虚拟表被用作下一个步骤的输入。只有最后一步生成的表返回给调用者。如果没有某一子句,则跳过相应的步骤。 

 1. FROM:对FROM子句中的前两个表执行笛卡尔积,生成虚拟表VT1。

 2. ON:对VT1应用ON筛选器。只有那些使<join_condition>为真的行才被插入VT2。 
 3. OUTER(JOIN):如果指定了OUTER JOIN,保留表中未找到匹配的行将作为外部行添加到VT2,生成VT3。

如果FROM子句包含两个以上的表,则对上一个联接生成的结果表和下一个表重复执行步骤1到步骤3,直到处理完所有的表为止。 

 4. 对VT3应用WHERE筛选器。只有使<where_condition>为TRUE的行才被插入VT4。 

 5. GROUP BY:按GROUP BY 子句中的列列表对VT4中的行分组,生成VT5。

 6. CUBE|ROLLUP:把超组插入VT5,生成VT6。 

 7. HAVING:对VT6应用HAVING筛选器。只有使<having_condition>为TRUE的组才会被插入VT7。 

 8. SELECT:处理SELECT列表,产生VT8。

 9. DISTINCT:将重复的行从VT8中移除,产生VT9。 

10. ORDER BY:将VT9中的行按ORDER BY子句中的列列表排序,生成一个有序表(VC10)。

11. TOP:从VC10的开始处选择指定数量或比例的行,生成表VT11,并返回给调用者。 

 

如果,您认为阅读这篇博客让您有些收获,不妨点击一下右下角的【推荐】。
如果,您希望更容易地发现我的新博客,不妨点击一下左下角的【关注我】。
如果,您对我的博客所讲述的内容有兴趣,请继续关注我的后续博客,我是【飞翔的小伟】,谢谢!

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

posted @ 2016-05-24 00:33  飞翔的小伟  阅读(1429)  评论(0编辑  收藏  举报