- 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,执行计划缓存(共4篇)
OracleERP最佳技术实践E-BUSINESSSUITE ORACLE性能优化之执行计划 Author: E-Mail: CreationDate: LastUpdated: DocumentRef: Version: Approvals: 苏南生#October19,XXOctober19,XXDRAFT1ACopyNumber_____ DocumentControl ChangeRecord Reviewers Distribution NoteToHolders:nameontheequivalentofthecoverpage,fordocumentcontrolpurposes.cover,fordocumentcontrolpurposes. ContentsDocumentControlii1.概要2SQL性能优化概要2SQL语句缓存2驱动表2组合索引32.执行计划5执行计划概要5执行计划案例一个5执行计划步骤6全表扫描7通过ROWID的表存取8索引扫描84种类型的索引扫描93.未完待续113.OpenandClosedIssuesforthisDeliverable12OpenIssues12ClosedIssues12 1.概要 October19,XX错误!未找到引用源。SQL性能优化概要在Oracle数据库应用系统中几乎有80%的性能问题是有糟糕的SQL语句引起的。优化是选择最有效的执行计划来执行SQL语句的过程,这是在处理任何数据的语句中的一个重要步骤。对Oracle来说,执行这样的语句有许多不同的方法,譬如说,将随着以什么顺序访问哪些表或索引的不同而不同。所使用的执行计划可以决定语句能执行得有多快。Oracle中称之为优化器的组件用来选择这种它认为最有效的执行计划。SQL语句缓存为了不重复解析相同的SQL语句(因为解析操作比较费资源,会导致性能下降),在第一次解析之后,ORACLE将SQL语句及解析后得到的执行计划存放在内存中。这块位于系统全局区域SGA(systemglobalarea)的共享池(sharedbufferpool)中的内存可以被所有的数据库用户共享。因此,当你执行一个SQL语句时,如果该语句和之前的执行过的某一语句完全相同,并且之前执行的该语句与其执行计划仍然在内存中存在,则ORACLE就不需要再进行分析,直接得到该语句的执行路径。ORACLE的这个功能大大地提高了SQL的执行性能并大大节省了内存的使用。使用这个功能的关键是将执行过的语句尽可能放到内存中,所以这要求有大的共享池(通过设置sharedbufferpool参数值)和尽可能的使用绑定变量的方法执行SQL语句。 共享池过小,会导致数据库性能降低,通过如下语句修改共享池的大小。驱动表驱动表(DrivingTable)。这个概念用于嵌套与HASH连接中。如果该表返回较多的行数据,则对所有的后续操作有负面影响。一般说来,是应用查询的限制条件后,返回较少行的表作为驱动表,所以如果一个大表在WHERE条件有限制条件(如等值限制), October19,XX错误!未找到引用源。则该大表作为驱动表也是合适的,所以并不是只有较小的表可以作为驱动表,正确说法应该为应用查询的限制条件后,返回较少行的表作为驱动表。在执行计划中,应该为靠上的那个表。例如:表A:cux_shipment_headers_all头表表B:cux_shp_deliveries_all行表情况一: 表cux_shipment_headers_all数据比较少,作为驱动表。情况二: 表cux_shp_deliveries_all限定查询条件,返回数据少,作为驱动表。组合索引由多个列构成的索引,如createindexidx_emponemp(col1,col2,col3,??),则我们称idx_emp索引为组合索引。在组合索引中有一个重要的概念:引导列(leadingcolumn),在上面的例子中,col1列为引导列。当我们进行查询时可以使用wherecol1=?,也可以使用wherecol1=?andcol2=?,这样的限制条件都会使用索引,但是wherecol2=?查询就不会使用该索引。所以限制条件中包含先导列时,该限制条件才会使用该组合索引。 目录 一.相关的概念 Rowid的概念 RecursiveSql概念 Predicate(谓词) DRivingTable(驱动表) ProbedTable(被探查表) 组合索引(concatenatedindex) 可选择性(selectivit
文档评论(0)