zoukankan      html  css  js  c++  java
  • SQL语句各子句的执行顺序

    一个SQL会包含很多个子句,在写SQL时,理解SQL个部分子句执行的优先级非常重要,否则可能会导致简单的SQL变成多个嵌套的SQL,更可能导致错误的返回结果。

    下面通过一个例子说明各子句的优先级:

     


    select a,b,count(sum(c)) over ()
    from t
    where t.d=1
    start with e is not null connect by prior f=g
    group by a,b
    having sum(c)>100
    order by 3;

    这个SQL包含:
    1. SELECT 子句
    2. group by子句
    3. 分析函数
    4. from子句
    5. where子句
    6. start with...connect by子句
    7. having子句
    8. order by子句


    对于FROM子句,可以简单理解为表或者扫描扫描(如果涉及到多表关联就复杂了,这里不讨论);
    对于SELECT子句,从执行计划看是在最后执行的,我把它理解为返回数据给用户,而不是读取数据,读取数据是在FROM这个步骤执行的,所以我认为顺序是:

    4 -> 6 -> 5 -> 2 -> 7 -> 3 -> 8 -> 1

    from子句 -> start with...connect by子句 -> where子句 -> group by子句 -> having子句 -> 分析函数 -> order by子句 -> SELECT 子句

    要注意,以上的顺序只代表一般情况,不一定所有的情况都按照这个执行顺序,尤其是同时有group by和order by时。例如:

    select a,b,count(sum(c)) over ()
    from t
    where t.d=1
    start with e is not null connect by prior f=g
    group by a,b
    having sum(c)>100
    order by a;

    这个SQL的执行顺序就有可能是:4->6->5-> 2 + 8 ->7->3->1。实际执行顺序以执行计划为准,但是这里特别要记住的是不管SQL怎么样,以下部分的优先级是确定的:

    start with...connect by子句 -> where子句 -> group by子句 -> having子句 -> 分析函数
  • 相关阅读:
    图像控件 ImageControl
    日期条控件 DateFieldControl
    日期选择器和日期条控件 DateChooserAndDateFieldControls
    计数器控件实例 NumericStepper
    树结构控件实例 TreeControl
    vue2.0leaflet
    关于工具类中@Autowired注入为NULL的问题记录
    zabbix_agentd重装后启动时IPC和共享内存段问题
    rsync如何不指定密码文件
    MySQL5.7 JSON类型及其相关函数的学习
  • 原文地址:https://www.cnblogs.com/goto/p/2824722.html
Copyright © 2011-2022 走看看