oracle 各部分执行顺序
Posted zhouyunchao
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle 各部分执行顺序相关的知识,希望对你有一定的参考价值。
查询语句的执行顺序:
1、FROM 子句:执行顺序为从后往前、从右到左。数据量较少的表尽量放在后面。
2、WHERE子句:执行顺序为自下而上、从右到左。将能过滤掉最大数量记录的条件写在WHERE 子句的最右。
3、GROUP BY:执行顺序从左往右分组,最好在GROUP BY前使用WHERE将不需要的记录在GROUP BY之前过滤掉。
4、HAVING 子句:消耗资源。尽量避免使用,HAVING 会在检索出所有记录之后才对结果集进行过滤,需要排序等操作。
5、SELECT子句:少用*号,尽量取字段名称。ORACLE 在解析的过程中, 通过查询数据字典将*号依次转换成所有的列名, 消耗时间。
6、ORDER BY子句:执行顺序为从左到右排序,消耗资源。
case
when 条件 then 结果
end
以上是关于oracle 各部分执行顺序的主要内容,如果未能解决你的问题,请参考以下文章