设为首页 加入收藏

TOP

Oracle数据库Where条件执行顺序及Where子句的条件顺序对性能的影响分析(二)
2018-03-14 09:00:33 】 浏览:345
Tags:Oracle 数据库 Where 条件 执行 顺序 性能 影响 分析
-----   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首先会找出条件中使用索引或表间连接的条件,以此来过滤数据集,然后对这些结果数据块所涉及的记录逐一检查是否符合所有条件,所以条件顺序对性能几乎没有影响。

首页 上一页 1 2 下一页 尾页 2/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇Oracle SQL语句执行流程与顺序原.. 下一篇select1frombwhereb.id=a.id和sel..

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目