Oracle WHER条件的执行顺序是不是自右向左

php中文网
发布: 2016-06-07 16:48:04
原创
1536人浏览过

突然在网上看到一种说法,ORACLE的WHERE条件执行顺序是自右向左的。理由是,当ORACLE的WHERE条件中出现多个00904表示符无效错误时

突然在网上看到一种说法,oracle的where条件执行顺序是自右向左的。
 
理由是,当oracle的where条件中出现多个00904表示符无效错误时,错误是从右向左的顺序报的。
 
也有人提出解析顺序和执行顺序不是一码事,执行顺序要看执行计划。
 
于是,我特地作了个试验。
 
现做一个试验用表
 
sql> select count(*) from dba_objects;
 

  COUNT(*)
 ----------
      72536


create table dba_objects2 as select * from dba_objects;


先来一次查询
 
SQL> select object_id,object_name from dba_objects2 where owner='HR' and object_id>500;
 

已选择41行。
 

 

执行计划
 ----------------------------------------------------------
 Plan hash value: 4278809457
 

----------------------------------------------------------------------------------
 | Id  | Operation        | Name        | Rows  | Bytes | Cost (%CPU)| Time    |
 ----------------------------------------------------------------------------------
 |  0 | SELECT STATEMENT  |              |  426 | 40896 |  283  (1)| 00:00:04 |
 |*  1 |  TABLE ACCESS FULL| DBA_OBJECTS2 |  426 | 40896 |  283  (1)| 00:00:04 |
 ----------------------------------------------------------------------------------
 

Predicate Information (identified by operation id):
 ---------------------------------------------------
 

百灵大模型
百灵大模型

蚂蚁集团自研的多模态AI大模型系列

百灵大模型 331
查看详情 百灵大模型

  1 - filter("OWNER"='HR' AND "OBJECT_ID">500)
 

Note
 -----
    - dynamic sampling used for this statement (level=2)
 

可以看出,这次Oracle是自左向右执行。那么SQL语句颠倒下会怎样?
 
SQL> select object_id,object_name from dba_objects2 where object_id>500 and owner='HR';
 

已选择41行。
 

 

执行计划
 ----------------------------------------------------------
 Plan hash value: 4278809457
 

----------------------------------------------------------------------------------
 | Id  | Operation        | Name        | Rows  | Bytes | Cost (%CPU)| Time    |
 ----------------------------------------------------------------------------------
 |  0 | SELECT STATEMENT  |              |  426 | 40896 |  283  (1)| 00:00:04 |
 |*  1 |  TABLE ACCESS FULL| DBA_OBJECTS2 |  426 | 40896 |  283  (1)| 00:00:04 |
 ----------------------------------------------------------------------------------
 

Predicate Information (identified by operation id):
 ---------------------------------------------------
 

  1 - filter("OWNER"='HR' AND "OBJECT_ID">500)
 

Note
 -----
    - dynamic sampling used for this statement (level=2)
 

实际的执行顺序是自右向左。难道oracle的执行顺序是看开销的?把尽可能多缩小数据范围的条件放在前面执行。
 

 

为了证明自己的想法,我又增加了一个条件。
 
SQL> select object_id,object_name from dba_objects2 where object_id>500 and object_name like '%EM%'  and owner='HR';
 

已选择14行。
 

 

执行计划
 ----------------------------------------------------------
 Plan hash value: 4278809457
 

----------------------------------------------------------------------------------
 | Id  | Operation        | Name        | Rows  | Bytes | Cost (%CPU)| Time    |
 ----------------------------------------------------------------------------------
 |  0 | SELECT STATEMENT  |              |  147 | 14112 |  283  (1)| 00:00:04 |
 |*  1 |  TABLE ACCESS FULL| DBA_OBJECTS2 |  147 | 14112 |  283  (1)| 00:00:04 |
 ----------------------------------------------------------------------------------
 

Predicate Information (identified by operation id):
 ---------------------------------------------------
 

  1 - filter("OBJECT_NAME" IS NOT NULL AND "OWNER"='HR' AND
              "OBJECT_ID">500 AND "OBJECT_NAME" LIKE '%EM%')
 

Note
 -----
    - dynamic sampling used for this statement (level=2)
 

ORACLE 智能的增加了"OBJECT_NAME" IS NOT NULL的条件,把放在中间的 OBJECT_NAME" LIKE '%EM%'放在了最后执行。
 
由此可见,,WHERE条件的执行顺序是按照开销的右小到大的顺序,智能调节的。

本文永久更新链接地址:

linux

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号