当前位置:  数据库>怎么写一个Shell来执行这样的功能,访问Oracle数据库,然后执行一个SQL脚本,生成一个文件。急! iis7站长之家

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

    来源: 互联网  发布时间:2017-06-03

    本文导语: 突然在网上看到一种说法,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):
 ---------------------------------------------------
 

  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条件的执行顺序是按照开销的右小到大的顺序,智能调节的。


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 怎么写一个Shell来执行这样的功能,访问Oracle数据库,然后执行一个SQL脚本,生成一个文件。急!
  • win2000+jbuilder6+oracle817编出的程序,在win2000下执行很好,在win98下却访问不了oracle数据库
  • oracle 可以在crontab 中定时执行吗?
  • oracle sql执行过程(流程图)
  • linux能够通过执行脚本添加oracle数据库的用户吗
  • ORACLE安装时/tmp/orainstRoot.sh 执行发生错误
  • 求救:HPUNIX下的ORACLE7执行select * from tablename提示权限不足!!
  • 为什么 export ORACLE_SID=test写在程序里面就不会执行?
  • 请问在 Linux 下如何用代码实现连接oracle数据库 并 执行 SQL 语句?
  • shell调用oracle储存过程,怎么判断储存过程执行结果是否正确
  • shell 执行oracle sql脚本的问题
  • oracle单库彻底删除干净的执行步骤
  • 查看Oracle的执行计划一句话命令
  • 关于ORACLE中执行批处理的问题
  • oracle中得到一条SQL语句的执行时间的两种方式
  • oracle导出sql语句的结果集和保存执行的sql语句(深入分析)
  • Nagios check_oracle_health 关于执行SQL问题
  • 执行Commit时Oracle做哪些工作
  • RedHat AS 4 安装oracle9i的时候,执行Disk1下的runInstaller后提示正在初始化虚拟机,请等待后就再无反应
  • JBUILDER如何执行ORACLE的储存过程
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,