- 1、本文档共22页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
(通过分析SQL语句的执行计划优化SQL二
5.1背景知识?????? 5.2执行计划的步骤及顺序?????? 5.3访问路径(方法) -- access path?????? 5.4表之间的连接
第5章 ORACLE的执行计划 5.1背景知识: ?? ??? 为了更好的进行下面的内容我们必须了解一些概念性的术语:共享sql语句 为了不重复解析相同的SQL语句(因为解析操作比较费资源,会导致性能下降),在第一次解析之后,ORACLE将SQL语句及解析后得到的执行计划存放在内存中。这块位于系统全局区域SGA(system global area)的共享池(shared buffer pool)中的内存可以被所有的数据库用户共享。因此,当你执行一个SQL语句(有时被称为一个游标)时,如果该语句和之前的执行过的某一语句完全相同,并且之前执行的该语句与其执行计划仍然在内存中存在,则ORACLE就不需要再进行分析,直接得到该语句的执行路径。ORACLE的这个功能大大地提高了 SQL的执行性能并大大节省了内存的使用。使用这个功能的关键是将执行过的语句尽可能放到内存中,所以这要求有大的共享池(通过设置shared buffer pool参数值)和尽可能的使用绑定变量的方法执行SQL语句。当你向ORACLE 提交一个SQL语句,ORACLE会首先在共享内存中查找是否有相同的语句。这里需要注明的是,ORACLE对两者采取的是一种严格匹配,要达成共享,SQL语句必须完全相同(包括空格,换行等)。下面是判断SQL语句是否与共享内存中某一SQL相同的步骤:1). 对所发出语句的文本串进行hashed。如果hash值与已在共享池中SQL语句的hash值相同,则进行第2步:?? ??? 2) ?? ?? 将所发出语句的文本串(包括大小写、空白和注释)与在第1步中识别的所有?? ??? 已存在的SQL语句相比较。?? ??? 例如:?? ??? SELECT * FROM emp WHERE empno = 1000; ?? ??? 和下列每一个都不同 ?? ??? SELECT * from emp WHERE empno = 1000;?? ??? SELECT * FROM EMP WHERE empno = 1000;?? ??? SELECT * FROM emp WHERE empno = 2000;?? ??? 在上面的语句中列值都是直接SQL语句中的,今后我们将这类sql成为硬编码SQL?? ??? 或字面值SQL?? ????? ??? 使用绑定变量的SQL语句中必须使用相同的名字的绑定变量(bind variables) ,例如: ?? ??? a. 该2个sql语句被认为相同?? ??? select pin , name from people where pin = :blk1.pin; ?? ??? select pin , name from people where pin = :blk1.pin; ?? ??? b. 该2个sql语句被认为不相同?? ??? select pin , name from people where pin = :blk1.ot_ind; ?? ??? select pin , name from people where pin = :blk1.ov_ind; ?? ??? 今后我们将上面的这类语句称为绑定变量SQL。?? ??? 3). 将所发出语句中涉及的对象与第2步中识别的已存在语句所涉及对象相比较。?? ?? ??? 例如: ?? ?? ??? 如用户user1与用户user2下都有EMP表,则?? ?? ??? 用户user1发出的语句:SELECT * FROM EMP; 与?? ?? ??? 用户user2发出的语句:SELECT * FROM EMP; 被认为是不相同的语句, ?? ?? ??? 因为两个语句中引用的EMP不是指同一个表。?? ??? 4). 在SQL语句中使用的捆绑变量的捆绑类型必须一致。?? ??? 如果语句与当前在共享池中的另一个语句是等同的话,Oracle并不对它进行语法分析。而直接执行该语句,提高了执行效率,因为语法分析比较耗费资源。?? ??? 注意的是,从oracle 8i开始,新引入了一个CURSOR_SHARING参数,该参数的主要目的就是为了解决在编程过程中已大量使用的硬编码SQL问题。因为在实际开发中,很多程序人员为了提高开发速度,而采用类似下面的开发方法:str_sql string;int_empno int;int_empno = 2000;str_sql = ‘SELECT
您可能关注的文档
- (新课程改革2014年二年级下册数学总备课.docx
- (通信原理粟向军期末考试复习资料整理2.doc
- (新课程改革下初中政治教学.doc
- (通信原理课程设计指导书2013.10.doc
- (裙楼加层混凝土工程施工方案.doc
- (通信原理课程设计指导书_2010_fnal.doc
- (新课程改革下初中数学教师专业素养的一点感想.doc
- (通信原理课程设计指导书_2011.doc
- (通中课题开题报告.doc
- (通信学院课程设计封面格式终稿.docx
- 2025年长沙银行浏阳支行社会招聘考试备考题库及答案解析.docx
- 2025年浙商银行成都分行社会招聘考试备考题库及答案解析.docx
- 2025中国农业科学院烟草研究所高层次人才招聘5人考试备考题库及答案解析.docx
- 2025中国冶金地质总局二局 国冶二局(福建)集团有限公司招聘10人考试备考题库及答案解析.docx
- 2025中国宗教杂志社招聘3人考试备考题库及答案解析.docx
- 2025年长沙银行益阳支行社会招聘考试备考题库及答案解析.docx
- 2025中国农业科学院农田灌溉研究所第二批招聘14人(河南)考试备考题库及答案解析.docx
- 2025中国农业科学院郑州果树研究所青年英才招聘3人考试备考题库及答案解析.docx
- 【统编版】高中语文必修上册第1单元2.1《立在地球边上放号》精美课件(23张PPT).pptx
- 【统编版】高一语文必修上册第一单元2.1《立在地球边上放号》优质课(26张PPT)课件.pptx
最近下载
- 牛津自然拼读oxfordphonicsLevel2Unit4Lesson2课件.pptx VIP
- 《梅花易数》预测实战方法.pdf VIP
- 医院地震应急演练脚本.docx VIP
- EPLAN笔记-EPLAN笔记-EPLAN笔记-EPLAN笔记.pdf VIP
- 污水处理厂应急预案.doc VIP
- 防火封堵工程施工与验收记录表(附件8)模板.pdf VIP
- 公路工程高程横坡计算程序(2011表格版).xls VIP
- BS EN 1822-1-2019 高效空气过滤器(EPA,HEPA和ULPA).第1部分:分类性能试验标记.pdf VIP
- 皇极经世预言未来的原理.pdf VIP
- 牛津自然拼读课件OPW PPT L2 U4 Lesson1.pptx VIP
文档评论(0)