SQL语句性能调整之ORACLE的执行计划.docx

  1. 1、本文档共35页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
SQL语句性能调整之ORACLE的执行计划

SQL语句性能调整之ORACLE的执行计划 【内容导航】 第1页: HYPERLINK /a2009/0423/273/000000273787.shtml \o 背景知识 背景知识 第2页: HYPERLINK /a2009/0423/273/000000273787_1.shtml \o Rowid的概念 Rowid的概念 第3页: HYPERLINK /a2009/0423/273/000000273787_2.shtml \o 可选择性 可选择性 第4页: HYPERLINK /a2009/0423/273/000000273787_3.shtml \o 执行计划的步骤 执行计划的步骤 第5页: HYPERLINK /a2009/0423/273/000000273787_4.shtml \o 访问路径(方法) -- access path 访问路径(方法) -- access path 第6页: HYPERLINK /a2009/0423/273/000000273787_5.shtml \o 4种类型的索引扫描 4种类型的索引扫描 第7页: HYPERLINK /a2009/0423/273/000000273787_6.shtml \o 表之间的连接 表之间的连接 第8页: HYPERLINK /a2009/0423/273/000000273787_7.shtml \o 嵌套循环(Nested Loops, NL) 嵌套循环(Nested Loops, NL) 第9页: HYPERLINK /a2009/0423/273/000000273787_8.shtml \o 如何产生执行计划 如何产生执行计划 第10页: HYPERLINK /a2009/0423/273/000000273787_9.shtml \o 如何分析执行计划 如何分析执行计划 第11页: HYPERLINK /a2009/0423/273/000000273787_10.shtml \o 对于RBO优化器 对于RBO优化器 第12页: HYPERLINK /a2009/0423/273/000000273787_11.shtml \o 对于CBO优化器 对于CBO优化器 第13页: HYPERLINK /a2009/0423/273/000000273787_12.shtml \o 如何干预执行计划 - - 使用hints提示 如何干预执行计划 - - 使用hints提示 第14页: HYPERLINK /a2009/0423/273/000000273787_13.shtml \o 使用全套的hints 使用全套的hints 第15页: HYPERLINK /a2009/0423/273/000000273787_14.shtml \o 具体案例分析 具体案例分析 文本Tag:  HYPERLINK /lists/6238/0/6238.shtml \t _blank Oracle  HYPERLINK /lists/5847/0/5847.shtml \t _blank 数据库  HYPERLINK /lists/10239/0/10239.shtml \t _blank Oracle数据库开发   【IT168 技术文档】   背景知识:   为了更好的进行下面的内容我们必须了解一些概念性的术语:   共享sql语句   为了不重复解析相同的SQL语句(因为解析操作比较费资源,会导致性能下降),在第一次解析之后,ORACLE将SQL语句及解析后得到的执行计划存放在 HYPERLINK /list/b/0205_1.shtml \o 内存 \t _blank 内存中。这块位于系统全局区域SGA(system global area)的共享池(shared buffer pool)中的内存可以被所有的数据库用户共享。因此,当你执行一个SQL语句(有时被称为一个游标)时,如果该语句和之前的执行过的某一语句完全相同,并且之前执行的该语句与其执行计划仍然在内存中存在,则ORACLE就不需要再进行分析,直接得到该语句的执行路径。ORACLE的这个功能大大地提高了SQL的执行性能并大大节省了内存的使用。使用这个功能的关键是将执行过的语句尽可能放到内存中,所以这要求有大的共享池(通过设置shared buffer pool参数值)和尽可能的使用绑定变量的方法执行SQL语句。   当你向ORACLE 提交一个SQL语句,ORACLE会首先在共享内存中查找是否有相同的语句。这里需要注明的是,ORACLE对两

文档评论(0)

wannian118 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档