`

oracle子句的执行顺序

 
阅读更多

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

分享到:
评论

相关推荐

    oracle select执行顺序的详解

    SQL Select语句完整的执行顺序:1、from子句组装来自不同数据源的数据;2、where子句基于指定的条件对记录行进行筛选;3、group by子句将数据划分为多个分组;4、使用聚集函数进行计算;5、使用having子句筛选分组;...

    Oracle SQL高级编程(资深Oracle专家力作,OakTable团队推荐)--随书源代码

    9.10.5 Model子句执行中的分区 250 9.10.6 索引 251 9.11 子查询因子化 252 9.12 小结 253 第10章 子查询因子化 254 10.1 标准用法 254 10.2 SQL优化 257 10.2.1 测试执行计划 257 10.2.2 跨多个执行的测试 ...

    Oracle数据库、SQL

    4.2语法和执行顺序 8 4.3字符串是大小写敏感的,在比较时严格区分大小写 8 4.4 where子句后面可以跟多个条件表达式 8 4.5 between and运算符 8 4.6 in运算符(多值运算符) 8 4.7 like运算符 9 4.8 is null运算符 9 ...

    ORACLE优化SQL语句,提高效率

     Oracle的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表(基础表 driving table)将被最先处理,在FROM子句中包含多个表的情况下,您必须选择记录条数最少的表作为基础表。假如有3个以上的表...

    oracle SQL性能优化

    ORACLE的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表(基础表 driving table)将被最先处理,在FROM子句中包含多个表的情况下,你必须选择记录条数最少的表作为基础表。如果有3个以上的表...

    Orcle面试知识点

    ORACLE的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表(基础表 driving table)将被最先处理,在FROM子句中包含多个表的情况下,你必须选择记录条数最少的表作为基础表。如果有3个以上的表...

    Oracle数据库Sql性能调优

    1.7 WHERE子句中的连接顺序 6 1.8 SELECT子句中避免使用 ‘ *‘ 7 1.9 减少访问数据库的次数 7 1.10 使用DECODE函数来减少处理时间 8 1.11 删除重复记录 8 1.12 用TRUNCATE替代DELETE 9 1.13 尽量多使用COMMIT 9 ...

    Oracle提高sql执行效率的心得建议

    代码如下: –>FROM子句中包含多个表的情况下,选择记录条数最少的表作为基础表 –>解析WHERE子句是自下而上的 过滤条件要有顺序 –>ORACLE会将’*’转换成列名 –>DELETE会在rollback segment中存放可恢复信息,可以...

    oracle sql performance tuning

    3.9 合理排列WHERE子句中的连接顺序. 9 3.10 用WHERE子句替换HAVING子句 9 3.11 关于使用索引(INDEX)的一些注意点 10 3.11.1 ‘!=’,NOT操作将不使用索引. 10 3.11.2 ‘||’是字符连接函数. 就象其它函数那样, ...

    oracle实验报告

    文件中每条SQL语句顺序装入缓冲区并执行。 二、 数据库命令——有关表、视图等的操作 1. 创建表employee 例1 定义一个人事信息管理系统中存放职工基本信息的一张表。可输入如下命令: SQL>CREATE TABLE employee ...

    Oracle_Database_11g完全参考手册.part2/3

    12.1.2 执行顺序 12.2 分组视图 12.3 用别名重命名列 12.4 分组视图的功能 12.4.3 对列和分组函数进行排序 12.4.4 连接列 12.5 更多分组可能性 第13章 当一个查询依赖于另一个查询时 13.1 高级子查询 13.1.1 相关子...

    Oracle_Database_11g完全参考手册.part3/3

    12.1.2 执行顺序 12.2 分组视图 12.3 用别名重命名列 12.4 分组视图的功能 12.4.3 对列和分组函数进行排序 12.4.4 连接列 12.5 更多分组可能性 第13章 当一个查询依赖于另一个查询时 13.1 高级子查询 13.1.1 相关子...

    oracle学习文档 笔记 全面 深刻 详细 通俗易懂 doc word格式 清晰 连接字符串

    oracle学习文档 笔记 全面 深刻 详细 通俗易懂 doc word格式 清晰 第一章 Oracle入门 一、 数据库概述 数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,它产生于距今五十年前。简单来说是本身可视...

    OCPOCA认证考试指南全册:Oracle Database 11g(1Z0-051,1Z0-052,1Z0-053)--详细书签版(第2/2部分)

     Bob Bryla是Oracle 9i和10g的认证专家,他在数据库设计、数据库应用程序开发、培训和Oracle数据库管理等方面拥有20多年的工作经验,他也足Dodgeville的Land'End公司的首席Internet数据库设计师和Oracle DBA. ...

    MYSQL查看执行计划

    1、 概述:  执行计划的查看是进行数据库的sql语句调优时依据的一个重要依据,mysql的执行计划查看相对oracle简便很多,功能也相对简单很多的SQL语句都不能直接查看。...  当id值一样的时候,执行顺序由上往下;

    数据库基础知识

    sqlplus 连接本地 quit ...cd MySql cd bin cd mysql -h192.168.1.32 -uroot -p ...sql语句执行的顺序:from子句---->where子句---->select子句--->order by子句 ='2010-07-22' 或是 = To_DATE('2010-07-22')

Global site tag (gtag.js) - Google Analytics