zoukankan      html  css  js  c++  java
  • 微软官方:SELECT语句逻辑处理顺序

     

    以下步骤显示SELECT 语句的逻辑处理顺序或绑定顺序。此顺序确定在一个步骤中定义的对象何时可用于后续步骤中的子句。

    例如,如果查询处理器可以绑定到(访问)在FROM 子句中定义的表或视图,则这些对象及其列可用于所有后续步骤。

    相反,因为SELECT 子句处于步骤8 中,所以,在该子句中定义的任何列别名或派生列不能由之前的子句引用。但是,它们可由后面的子句(例如ORDER BY 子句)引用。

    请注意,该语句的实际物理执行由查询处理器确定,因此在此列表中顺序可能会不同。

    (1)FROM

    (2)ON

    (3)JOIN

    (4)WHERE

    (5)GROUP BY

    (6)WITH CUBE 或WITH ROLLUP

    (7)HAVING

    (8)SELECT

    (9)DISTINCT

    (10)ORDER BY

    (11)TOP

    (8)SELECT (9)DISTINCT (11)TOP

    (1)FROM 

    (3)JOIN   (2)ON 

    (4)WHERE

    (5)GROUP BY 

    (6)WITH {CUBE ROLLUP}

    (7)HAVING 

    (10)ORDER BY

    对于JOIN参与的表的关联操作,如果需要不满足连接条件的行也在我们的查询范围内的话,我们就必需把连接条件放在ON后面,而不能放在WHERE后面,如果我们把连接条件放在了WHERE后面,那幺所有的LEFT,RIGHT,等这些操作将不起任何作用,对于这种情况,它的效果就完全等同于INNER连接。对于那些不影响选择行的条件,放在ON或者WHERE后面就可以。

    记住:所有的连接条件都必需要放在ON后面,不然前面的所有LEFT,和RIGHT关联将作为摆设,而不起任何作用。

    (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子句包含两个以上的表,则对上一个联接生成的结果表和下一个表重复执行步骤到步骤,直到

    处理完所有的表为止。

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

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

    6. CUBEROLLUP:把超组插入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,并返回给调用者。

  • 相关阅读:
    linux拷贝文件右键无粘贴功能
    Talk is cheap,show me the code!
    wireshark 分析mptcp序列号
    wireshark提取cwnd的语句
    (转)Wireshark查看重传包对应关系
    如何在Virtualbox中对Linux(Ubuntu)系统根分区扩容
    ns2中gnuplot不显示图像解决方法
    直接检测拥塞窗口大小的Tcpprobe
    mininet monitor
    mininet Red-ecn
  • 原文地址:https://www.cnblogs.com/wwxbi/p/4136280.html
Copyright © 2011-2022 走看看