ORACLE执行计划和SQL调优知识概述(PPT).pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
ORACLE执行计划和SQL调优知识概述(PPT)

调整表连接 表连接方法 嵌套循环连接(nested loop join):一个小的内部表和一个外部表。比较内部表的每一条记录和外部表的每一条记录,返回满足条件的记录; 散列连接(hash join):为较小的表在RAM创建散列表(可以用来从较大的那个表读取记录); 排序合并连接(sort merge join):使用连接字段将两个记录集排序然后合并; 星型连接(star join):几个小型表(将组成虚拟表)和一个大型事实表,然后进行嵌套循环连接; 表连接类型 等连接:标准连接;…from a,b where a.f1=b.f1;oracle提供nested loop、hash join、sort merge三种连接方式; 外部连接: 通过在where子句的等式谓词展览馆放置一个(+)来实现;…from a,b where a.f1=b.f1(+),将包括b表中不匹配的字段; 自连接:一个表与自己连接的情况;…from emp a,emp b where a.f1-b.f1 =10 …;经常调用nested loop连接; 表连接类型(续) 反连接:指使用包含not in 或not exists子句的子查询进行的连接;默认使用嵌套循环算法; 半连接:指在子查询中使用in或exists子句时进行的操作; 表连接调整原则 RBO只能调用nested loop和merge sort连接;hash join和star 连接只能在CBO中得到; 尽量不要使用not in反连接子查询,把它替换成标准等连接,用外连接和where column is null子句删除多余的记录;或者尽量替换成not exists子查询,因为它将调用相关联的子查询; 半连接子查询可以重新书写成标准等连接,用select distinct子句删除重复的记录; 表连接调整原则(续) 如果驱动表较小,可以完全装入hash_area_size内存中,使用散列连接(hash join)速度比嵌套循环连接(nested loop)快; 在两个表非常大的情况下,经常使用嵌套循环连接(nested loop); 生成大型结果集的查询、不使用where子句的大表连接或表中无可用索引的查询,经常使用排序合并连接(srot merge); 对于多个小的维表和一个大的事实表的情况下(数据仓库),经常使用星型连接(star); 不同表连接方法的相对速度 星型连接 嵌套循环连接 散列连接 排序合并连接 连接速度 连接表中记录的数目 少 多 慢 快 调整SQL子查询 子查询类型 标准子查询:in 和 exists; 反连接子查询:not in 和 not exists; 关联子查询:指在子查询内部引用外部数据表;…from table1 a where … (select…from table2 b Where a.f1 = b.f1…);对于外部数据集的每一条记录,都将重新执行一次内部子查询; 非关联子查询:指在子查询内部不会引用外部的数据表;…from table1 a where … (select …from table2 b …);内部子查询只执行一次; 子查询调整原则 只要可能的话,尽可能的避免使用子查询,而用标准的连接操作来代替,这样可以使用提示来更改执行计划; 先考虑子查询的合法性,再考虑进行改写; 使用一个关联子查询时,in与exists子句的子查询的执行计划基本相同; 在外部查询返回相对较少的记录时,关联子查询比非关联子查询执行得更快; 子查询调整原则(续) 在内部子查询只有少量的记录时,非关联子查询比关联子查询执行得更快; 关联子查询使用in子句是多余的;而非关联子查询使用exists子句是不恰当的。 使用in子句的非关联子查询可以转换为标准连接操作以及使用select distinct来删除重复的记录; 使用exists子句的关联子查询可以转换为标准连接,但子查询最好只能返回一个记录; 子查询调整原则(续) 非关联子查询使用not exists子句是没有意义的; 使用not in子句的非关联子查询可以转sql minus子句,性能相对会高一些; 使用not in子句的关联子查询,可以使用带有select distinct子句的外部连接操作改写; 各种子查询技术总结 标准子查询 反连接子查询 in exists Not in Not exists 关联子查询 多余的 自动转换为嵌套的循环连接 可以重写为select distinct 外部连接 可以重写为select distinct 外部连接 非关联子查询 自动转换为嵌套的循环连接 不适合 可以重写为minus操作符的嵌套循环连接 不适合 例子:使用in子句的非关联子查询可以使用标准连接操作以及使用select

文档评论(0)

tangtianxu1 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档