SQL语句各子句的执行顺序

转载 2012年03月23日 01:11:24

一个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子句 -> 分析函数

相关文章推荐

含有GROUP BY子句的查询中如何显示COUNT()为0的结果( SELECT语句完整的执行顺序)

含有GROUP BY子句的查询中如何显示COUNT()为0的结果 本文我们主要介绍了SQL Server数据库中在使用GROUP BY对查询出的结果进行分组时,COUNT()为0的结果无...
  • haiross
  • haiross
  • 2014年11月03日 15:07
  • 1768

SQL子句执行顺序和Join的一点总结

SQL子句执行顺序和Join的一点总结 1.笛卡尔积(Cartesian product) 顾名思义, 这个概念得名于笛卡儿. 在数学中,两个集合 X 和 Y 的笛卡儿积(Cartesian ...

化简复杂逻辑,编写紧凑的if条件语句(三):确定最简的if子句顺序

《化简复杂逻辑,编写紧凑的if条件语句(二):依据if子句顺序化简条件》已经按照跳等飞异的顺序化简了逻辑条件。这一篇来讨论怎样的情况顺序可以产生最简的if子句。方便起见这里重新贴一下跳、等、飞、异常的...
  • gqqnb
  • gqqnb
  • 2013年08月30日 21:57
  • 1046

sql语句where子句like的用法详解

在SQL结构化查询语言中,LIKE语句有着至关重要的作用。 LIKE语句的语法格式是:select * from 表名 where 字段名 like 对应值(子串),它主要是针对字符型字段的,它的作...

SQL语句中,WHERE子句不能有聚合函数问题

一般SQL语句中,WHERE子句是不能含有聚合函数的,否则报错:group function is not allowed here,那么我们如何去处理呢? 如下SQL: SELECT    T...

SQL语句中where 1=1 对性能的影响,where 与having的区别,where子句的性能

1,where 1=1 对性能的影响 很多时候,使用where 1=1 可以很方便的解决我们的问题,但是这样很可能会造成非常大的性能损失,因为添加使用了 “where 1=1 ”的过滤条件以后数据库...

Oracle-18-select语句初步&SQL中用算术表达式&别名的使用&连接运算符%distinct&where子句

一、一般SELECT语句的格式如下: 1.查询指定表的所有列 select * from 表名 [where 条件] [group by 分组列名] [having 聚合函数] [order...
  • wy_0928
  • wy_0928
  • 2016年04月14日 18:52
  • 5205

SQL Select语句完整的执行顺序

  • 2013年11月22日 13:48
  • 656B
  • 下载

SQL语句之ORDER BY子句

对结果进行排序(ORDER BY子句)       在SQL中可以使用ORDER BY子句对查询的结果进行排序。       例:现在使用查询全部的语句查询表EMP...

SQL-SELECT 语句,From子句,where条件查询

SELECT 语句  SELECT 语句用来检索数据表中的数据,而哪些数据被检索由列出的数据行与语句中的 WHERE 子句决定。例如,要从之前建立的 Customer_Data数据表中检索 custo...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:SQL语句各子句的执行顺序
举报原因:
原因补充:

(最多只允许输入30个字)