- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
.专业整理 .
Oracle 执行计划
1,什么是执行计划
所谓执行计划 ,顾名思义 ,就是对一个查询任务 ,做出一份怎样去完成任务的
详细方案 。举个生活中的例子 ,我从珠海要去英国 ,我可以
选择先去香港然后转机 ,也可以先去北京转机 ,或者去广州也可以 。 但是到底
怎样去英国划算 ,也就是我的费用最少 ,这是一件值得考究
的事情 。 同样对于查询而言 ,我们提交的 SQL 仅仅是描述出了我们的目的地是
英国,但至于怎么去 ,通常我们的 SQL 中是没有给出提示信息
的,是由数据库来决定的 。
我们先简单的看一个执行计划的对比 :
SQL set autotrace traceonly
执行计划一 :
SQL select count(*) from t;
COUNT(*)
----------
24815
Execution Plan
0 SELECT STATEMENT Optimizer=CHOOSE
. 学习帮手 .
.专业整理 .
0 SORT (AGGREGATE)
1TABLE Access (FULL) OF T
执行计划二 :
SQL select count(*) from t;
COUNT(*)
24815
Execution Plan
SELECT STATEMENT Optimizer=CHOOSE (Cost=26 Card=1)
0 SORT (AGGREGATE)
1 INDEX (FULL SCAN) OF T_INDEX (NON-UNIQUE) (Cost=26 Card=28180)
这两个执行计划中 ,第一个表示求和是通过进行全表扫描来做的 ,把整个
表中数据读入内存来逐条累加 ;第二个表示根据表中索引 ,把
整个索引读进内存来逐条累加 ,而不用去读表中的数据 。但是这两种方式到底
哪种快呢 ?通常来说可能二比一快 ,但也不是绝对的 。这是一
个很简单的例子演示执行计划的差异 。 对于复杂的 SQL(表连接、嵌套子查询
等 ),执行计划可能几十种甚至上百种 ,但是到底那种最好呢 ?
. 学习帮手 .
.专业整理 .
我们事前并不知道 ,数据库本身也不知道 ,但是数据库会根据一定的规则或者
统计信息 (statistics) 去选择一个执行计划 ,通常来说选择的是
比较优的 ,但也有选择失误的时候 ,这就是这次讨论的价值所在 。
Oracle 优化器模式
Oracle 优化器有两大类 ,基于规则的和基于代价的 ,在 SQLPLUS中我们
可以查看 init 文件中定义的缺省的优化器模式 。
SQL show parameters optimizer_mode
NAME TYPE VALUE
optimizer_mode string CHOOSE
SQL
这是企业版,我们可以看出 ,默认安装后数据库优化器模式为
CHOOSE,我们还可以设置为 RULE、
FIRST_ROWS,ALL_ROWS。可以在 init 文件中对整个 instance 的所有会话设
置,也可以单独对某个会话设置 :
SQL ALTER SESSION SET optimizer_mode = RULE;
会话已更改 。
SQL ALTER SESSION SET optimizer_mode = FIRST_ROWS;
. 学习帮手 .
.专业整理 .
会话已更改 。
SQL ALTER SESSION SET optimizer_mode = ALL_ROWS;
会话已更改 。
基于规则的查询 ,数据库根据表和索引等定义信息 ,按照一定的规则来产
生执行计划 ;基于代价的查询 ,数据库根据搜集的表和索引的
数据的统计信息 (通过 analyze 命令或者使用 dbms_stats 包来搜集 )综合来决定
选取一个数据库认为最优的执行计划 (实际上不一定最优 )。
RULE 是基于规则的 ,CHOOSE 表示如果查询的表存在搜集的统计信息则基于
代价来执行 (在 CHOOSE 模式下 Oracle 采用的是 FIRST_ROWS)
,否则基于规则来执行 。 在基于代价的两种方式中 ,FIRST_ROWS指执行计划
采用最少资源尽快的返回部分结果给客户端 ,对于排序分页
页显示这种查询尤其适用 ,ALL_ROWS 指以总体消耗资源最少的方式返回结果
给客户端 。
基于规则的模式下 ,数据库的执行计划通常比较稳定 。但在基于代价的模
式下,我们才有更大的机会选择最优的执行计划 。也由于
Oracle 的很多查询方面的特性必须在基于代价的模式下才能体现出来 ,所以我
们通常不选择 RULE(并且 Oracle 宣称从 Oracle 10i 版本数据库
. 学习帮手 .
.专业整理 .
开始将不再支
您可能关注的文档
最近下载
- 2025年宿迁市公需考试试题.docx VIP
- DB33_1092-2021《绿色建筑设计标准》.docx VIP
- 勘察设计的工作大纲.doc
- 新版青岛版三年级上册数学全册教案教学设计含教学反思.doc
- 草间弥生的奇幻南瓜 教学.ppt VIP
- 人教版(PEP)新教材小学五年级英语上册Unit 4 第2课时 A learn教学设计.docx VIP
- 八仙过海民间故事PPT课件.pptx VIP
- 6岁-8岁 水彩笔 《波点女王岁-草间弥生》-美术课件 (3).pptx VIP
- 山东版小学心理健康教育四年级上册《让推测更准确》课件.ppt VIP
- T-QAS 124-2025《冬虫夏草菌土制备技术规范》.docx VIP
原创力文档


文档评论(0)