zoukankan      html  css  js  c++  java
  • 容易被忽略的事----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,并返回给调用者。 

     

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

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

    始终相信分享是一种美德,谢谢您的光顾!
  • 相关阅读:
    leetcode 1140. Stone Game II
    主席树
    Codeforces Round #442 (Div. 2) E Danil and a Part-time Job (dfs序加上一个线段树区间修改查询)
    UVALive 3942 Remember the Word
    UVA 11235 Frequent values (RMQ )
    CodeForces
    hdu 2955 Robberies (01背包好题)
    hdu 1054 Strategic Game (简单树形DP)
    hdu 5532 Almost Sorted Array (水题)
    hdu 2089 不要62 (数位dp基础题)
  • 原文地址:https://www.cnblogs.com/zzw081210/p/5522052.html
Copyright © 2011-2022 走看看