2.表连接的时候,大表与小表的顺序是哪个在前.
3.在多表连接时,是表与表先连接起来,再执行对单表的限制条件where条件;还是先执行单表的限制where条件,再进行表连接?
4.多表连接时,如4个表,我自己做了一个实验:4个表连接执行查询vs2个表查询放入临时表再关联到一起查询。结果是后者的效率更高些。没有想通是问什么,按道理,后者有更多的io耗费呀!

---

oracle中Where子句的条件顺序对性能的影响:
  经常有人问到oracle中的Where子句的条件书写顺序是否对SQL性能有影响,我的直觉是没有影响,因为如果这个顺序有影响,Oracle应该早就能够做到自动优化,但一直没有关于这方面的确凿证据。在网上查到的文章,一般认为在RBO优化器模式下无影响(10G开始,缺省为RBO优化器模式),而在CBO优化器模式下有影响,主要有两种观点:
  a.能使结果最少的条件放在最右边,SQL执行是按从右到左进行结果集的筛选的;
  b.有人试验表明,能使结果最少的条件放在最左边,SQL性能更高。
  查过oracle8到11G的在线文档,关于SQL优化相关章节,没有任何文档说过where子句中的条件对SQL性能有影响,到底哪种观点是对的,没有一种确切的结论,只好自己来做实验证明。结果表明,SQL条件的执行是从右到左的,但条件的顺序对SQL性能没有影响。
  实验一:证明了SQL的语法分析是从右到左的
  下面的试验在9i和10G都可以得到相同的结果: 第1条语句执行不会出错,第2条语句会提示除数不能为零。
  1.Select 'ok' From Dual Where 1 / 0 = 1 And 1 = 2;
  2.Select 'ok' From Dual Where 1 = 2 And 1 / 0 = 1;
  证明了SQL的语法分析是从右到左的。
  实验二:证明了SQL条件的执行是从右到左的
  drop table temp; 
  create table temp( t1 varchar2(10),t2 varchar2(10)); 
  insert into temp values('zm','abcde'); 
  insert into temp values('sz','1'); 
  insert into temp values('sz','2'); 
  commit;
  1. select * from temp where to_number(t2)>1 and t1='sz';
  2. select * from temp where t1='sz' and to_number(t2)>1;
  在9i上执行, 第1条语句执行不会出错,第2条语句会提示“无效的数字”
  在10G上执行,两条语句都不会出错。
  说明:9i上,SQL条件的执行确实是从右到左的,但是10G做了什么调整呢?
  实验三:证明了在10g上SQL条件的执行是从右到左的
Create Or Replace Function F1(v_In Varchar2) Return Varchar2 Is 
  Begin 
  Dbms_Output.Put_Line('exec F1'); 
  Return v_In; 
  End F1; 
  / 
  Create Or Replace Function F2(v_In Varchar2) Return Varchar2 Is 
  Begin 
  Dbms_Output.Put_Line('exec F2'); 
  Return v_In; 
  End F2; 
  / 
  SQL> set serverout on; 
  SQL> select 1 from dual where f1('1')='1' and f2('1')='1'; 
  1 
  ---------- 
  1 
  exec F2 
  exec F1 
  SQL> select 1 from dual where f2('1')='1' and f1('1')='1'; 
  1 
  ---------- 
  1 
  exec F1 
  exec F2
  结果表明,SQL条件的执行顺序是从右到左的。
  那么,根据这个结果来分析,把能使结果最少的条件放在最右边,是否会减少其它条件执行时所用的记录数量,从而提高性能呢?
  例如:下面的SQL条件,是否应该调整SQL条件的顺序呢?
  Where A.结帐id Is Not Null
  And A.记录状态<>0
  And A.记帐费用=1
  And (Nvl(A.实收金额, 0)<>Nvl(A.结帐金额, 0) Or Nvl(A.结帐金额, 0)=0)
  And A.病人ID=[1] And Instr([2],','||Nvl(A.主页ID,0)||',')>0
  And A.登记时间Between [3] And [4]
And A.门诊标志<>1
  实际上,从这条SQL语句的执行计划来分析,Oracle首先会找出条件中使用索引或表间连接的条件,以此来过滤数据集,然后对这些结果数据块所涉及的记录逐一检查是否符合所有条件,所以条件顺序对性能几乎没有影响。
Create Or Replace Function F1(v_In Varchar2) Return Varchar2 Is 
  Begin 
  Dbms_Output.Put_Line('exec F1'); 
  Return v_In; 
  End F1; 
  / 
  Create Or Replace Function F2(v_In Varchar2) Return Varchar2 Is 
  Begin 
  Dbms_Output.Put_Line('exec F2'); 
  Return v_In; 
  End F2; 
  / 
  SQL> set serverout on; 
  SQL> select 1 from dual where f1('1')='1' and f2('1')='1'; 
  1 
  ---------- 
  1 
  exec F2 
  exec F1 
  SQL> select 1 from dual where f2('1')='1' and f1('1')='1'; 
  1 
  ---------- 
  1 
  exec F1 
  exec F2
  结果表明,SQL条件的执行顺序是从右到左的。
  那么,根据这个结果来分析,把能使结果最少的条件放在最右边,是否会减少其它条件执行时所用的记录数量,从而提高性能呢?
  例如:下面的SQL条件,是否应该调整SQL条件的顺序呢?
  Where A.结帐id Is Not Null
  And A.记录状态<>0
  And A.记帐费用=1
  And (Nvl(A.实收金额, 0)<>Nvl(A.结帐金额, 0) Or Nvl(A.结帐金额, 0)=0)
  And A.病人ID=[1] And Instr([2],','||Nvl(A.主页ID,0)||',')>0
  And A.登记时间Between [3] And [4]
  And A.门诊标志<>1
  实际上,从这条SQL语句的执行计划来分析,Oracle首先会找出条件中使用索引或表间连接的条件,以此来过滤数据集,然后对这些结果数据块所涉及的记录逐一检查是否符合所有条件,所以条件顺序对性能几乎没有影响。

---

2,大表放后面,优先解析
3,先where条件后连接多表,缩小关联表的数据量
4,临时表虽然浪费io,但是省了内存,数据量大的时候,反而效率更高

---以下内容来自摘抄,感觉两种情况应该一样,是n*m--有明白这种算法的欢迎讨论交流--

SQL两表关联查询where条件中等号两端字段顺序对效率的影响
现有两表A(大)、B(小)作关联查询,SQL语句如下:
 SQL1:select * from A,B where A.id = B.id
 SQL2:select * from A,B where B.id = A.id
在写SQL的时候可能这个顺序都是随便写的,当然SQL1和SQL2 执行的结果是完全相同的,那效率是否也一样呢,答案是否定的。
 SQL1 相当于将A表的id取出来,然后遍历B表进行查询,SQL2相当于将B表的id取出来,然后遍历A表进行查询。
如果表A的记录条数为m,表B的记录条数为n,SQL1比较的次数为n的m次方,SQL2比较的次数为m的n次方。
所以在一般情况下,表A大,表B小的时候,SQL2的效率更高。
在一般情况下,表A大,表B小的时候,SQL2的效率更高

---

新旧有差,基于规则的数据库,看执行

where的顺序对运行的影响--无影响的更多相关文章

  1. 异常处理 try...catch...finally 执行顺序, 以及对返回值得影响

    异常处理 try...catch...finally 执行顺序, 以及对返回值得影响 结论:1.不管有没有出现异常,finally块中代码都会执行:2.当try和catch中有return时,fina ...

  2. 以管理员身份运行 cmd 删除无权限删除的文件夹

    rd 文件夹 PS:删除空文件夹 rd /s 文件夹 PS:删除文件夹,及所有子目录和文件 rd /s/q 文件夹 PS:强制删除文件夹,及所有子目录和文件,不需要提示

  3. Rust语言——无虚拟机、无垃圾收集器、无运行时、无空指针/野指针/内存越界/缓冲区溢出/段错误、无数据竞争

    2006年,编程语言工程师Graydon Hoare利用业余时间启动了Rust语言项目.该项目充分借鉴了C/C++/Java/Python等语言的经验,试图在保持良好性能的同时,克服以往编程语言所存在 ...

  4. Erlang运行时中的无锁队列及其在异步线程中的应用

    本文首先介绍 Erlang 运行时中需要使用无锁队列的场合,然后介绍无锁队列的基本原理及会遇到的问题,接下来介绍 Erlang 运行时中如何通过“线程进度”机制解决无锁队列的问题,并介绍 Erlang ...

  5. 破解激活Win10无风险?激活后删除激活工具无影响===http://www.pconline.com.cn/win10/693/6932077_all.html#content_page_4

    1Windows激活:测试环境搭建 随着Windows 10的发布,许多用户都用上了这个新一代的操作系统.Windows 10有个最好的设置就是,只要你在已经激活的旧系统中升进行升级操作,就能获得一个 ...

  6. SQLite中字段顺序和PAGE_SIZE对性能的影响

    1.背景 SQLite数据库中有1张表,该表含若干个字段,其中有1个字段为BLOB类型,且BLOB字段不是最后1个字段.表结构类似如下(col3为BLOB字段): T (col1 INTEGER,co ...

  7. VirtualBox后台运行虚拟机(无图形界面启动虚拟机)

    有时候可能会用虚拟机搭建集群,这是通常希望不现实图形界面,试了半天,似乎只有Virtual Box支持无图形界面运行虚拟机,方法如下: 在Virtual Box的安装目录中找到VBoxManage,M ...

  8. 安装nodejs 后运行 npm 命令无响应处理方法

    安装和卸载过nodejs, 也编辑过 C:\Users\{账户}\下的.npmrc文件. 再全新安装nodejs ,运行npm 命令,无响应. 处理方法,删除C:\Users\{账户}\下的.npmr ...

  9. [工具] 解决sublime text运行javascript console无输出问题

    1.使用nodeJS在sublime text 运行javascript 下载安装nodeJS 在sublime text新建build system:tools->build system-& ...

随机推荐

  1. @@identity与SCOPE_IDENTITY的区别

    @@identity与SCOPE_IDENTITY的区别 共同点: SCOPE_IDENTITY 和 @@IDENTITY 返回在当前会话中的任何表内所生成的最后一个标识值. 不同处:SCOPE_ID ...

  2. MySQL数据分组Group By 和 Having

    现有以下的学生信息表: 若果现在想计算每个班的平均年龄,使用where的操作如下: SELECT Cno AS 班级, AVG(Sage) AS 平均年龄 FROM stu ; 这样的话,有多少个班就 ...

  3. kbengine学习2 创建项目

    官方文档https://www.comblockengine.com/docs/1.0/get-started/createproject/ 1.kbe服务器端 1.1 复制出一个assets文件夹, ...

  4. Access大数据高效分页语句

    Access大数据高效分页语句 oracle的分页查询可以利用rowid伪列. db2的分页查询可以利用row_number() over()聚合函数. mysql有limit. access仿佛先天 ...

  5. 如何调节tomcat初始内存

    1.linux下调节tomcat初始内存大小 linux下tomcat的运行文件为catalina.sh,打开文件,在文件靠近顶部找到“ JAVA_OPTS ”字样,在它后面添加如下内容即可 # JA ...

  6. (转+整理)C#中使用GUID

    GUID(全局统一标识符)是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的.通常平台会提供生成GUID的API.生成算法很有意思,用到了以太网卡地址.纳秒级时间.芯片ID码和许多可 ...

  7. Abstract Class 一些要点

    抽象类不能使用new operator创建实例. 抽象方法无需实现即可定义.其实现由子类完成. 包含抽象方法的类必须被定义成抽象的. 抽象类的构造函数可以定义成protected,因为它只会被子类使用 ...

  8. Centos6.8 smokeping安装

    yum -y install rrdtool perl-rrdtool curl perl-core bind bind-chroot bind-utils httpd popt popt-devel ...

  9. c# HTML中提取图片地址

    public class HtmlHelper    {        /// <summary>        /// HTML中提取图片地址        /// </summa ...

  10. Bitmap Byte[] 互转

    严正声明:作者:psklf出处: http://www.cnblogs.com/psklf/p/5889978.html欢迎转载,但未经作者同意,必须保留此段声明:必须在文章中给出原文连接:否则必究法 ...