oracle子句的执行顺序oracle
一个SQL会包含不少个子句,在写SQL时,理解SQL个部分子句执行的优先级很是重要,不然可能会致使简单的SQL变成多个嵌套的SQL,更可能致使错误的返回结果。ide
下面经过一个例子说明各子句的优先级:函数
select a,b,count(sum(c)) over ()spa
from tit
where t.d=1io
start with e is not null connect by prior f=gclass
group by a,bselect
having sum(c)>100数据
order by 3;margin
这个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子句 -> 分析函数