


下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、消耗在准备利用 Oracle执行计划机制提高查询性能新的 SQL语句的时间是 Oracle SQL 语句执行时间的最重要的组成部分。但是通过理解Oracle内部产生执行计划的机制,你能够控制Oracle花费在评估连接顺序的时间数量,并且能在大体上提高查询性能。准备执行SQL语句当SQL语句进入Oracle的库缓存后,在该语句准备执行之前,将执行下列步骤:1)语法检查:检查 SQL语句拼写是否正确和词序。2)语义分析:核实所有的与数据字典不一致的表和列的名字。3)轮廓存储检查:检查数据字典,以确定该SQL语句的轮廓是否已经存在。4)生成执行计划:使用基于成本的优化规则和数据字典中的统计表来决定最
2、佳执行计 划。5)建立二进制代码:基于执行计划,Oracle生成二进制执行代码。一旦为执行准备好了SQL语句,以后的执行将很快发生,因为Oracle认可同一个SQL语句,并且重用那些语句的执行。然而,对于生成特殊的SQL语句,或嵌入了文字变量的SQL语句的系统,SQL执行计划的生成时间就很重要了,并且前一个执行计划通常不能够 被重用。对那些连接了很多表的查询,Oracle需要花费大量的时间来检测连接这些表的适当顺序。评估表的连接顺序在SQL语句的准备过程中,花费最多的步骤是生成执行计划,特别是处理有多个表连 接的查询。当 Oracle评估表的连接顺序时,它必须考虑到表之间所有可能的连接。例如:
3、 六个表的之间连接有 720( 6的阶乘,或6 * 5 * 4 * 3 * 2 * 1 = 720)种可能的连接线路。当一个查询中含有超过 10个表的连接时,排列的问题将变得更为显著。对于15个表之间的连接,需要评估的可能查询排列将超过1万亿(准确的数字是1,307,674,368,000)种。使用 optimizer_search_limit 参数来设定限制通过使用optimizer_search_limit参数,你能够指定被优化器用来评估的最大的连接组合 数量。使用这个参数,我们将能够防止优化器消耗不定数量的时间来评估所有可能的连接组 合。如果在查询中表的数目小于optimizer_sea
4、rch_limit的值,优化器将检查所有可能的连接组合。例如:有五个表连接的查询将有120( 5! = 5 * 4 * 3 * 2 * 1 = 120 )种可能的连接组合,因此如果optimizer_search_limit等于5 (默认值),则优化器将评估所有的120种可能。optimizer_search_limit参数也控制着调用带星号的连接提示的阀值。当查询中的表的数目比 optimizer_search_limit小时,带星号的提示将被优先考虑。另一个工具:参数 optimizer_max_permutati ons初始化参数optimizer_max_permutations定义了
5、优化器所考虑组合数目的上限,且依赖 于初始参数 optimizer_search_limit 。 optimizer_max_permutations 的默认值是 80,000。参数 optimizer_search_limit 禾口 optimizer_max_permutations 起来确定优化器所考虑的组 合数目的上限:除非(表或组合数目)超过参数 optimizer_search_limit或者 optimizer_max_permutations设定的值,否则优化器将生成所有可能的连接组合。一旦优化器停止评估表的连接组合,它将选择成本最低的组合。使用ordered提示指定连接顺序你
6、能够设定优化器所执行的评估数目的上限。但是即使采用有很高价值的排列评估, 我们仍然拥有使优化器可以尽早地放弃复杂的查询的重要机会。回想一下含有15个连接查询的例子,它将有超过 1万亿种的连接组合。如果优化器在评估了80,000个组合后停止,那 么它才仅仅评估了 0.000006%的可能组合,而且或许还没有为这个巨大的查询找到最佳的连 接顺序。在Oracle SQL中解决此问题的最好的方法是手工指定表的连接顺序。为了尽快创建最 小的解决方案集,这里所遵循的规则是将表结合起来,通常优先使用限制最严格的WHERE子句来连接表。下面的代码是一个查询执行计划的例子,该例子在emp表的关联查询上强制执行了
7、嵌套的循环连接。注意,我已经使用了ordered提示来直接最优化表的评估顺序,最终它们表现在WHERE子句上。select /*+ ordered use_ nl(b onus) parallel® 4) */e.e name,hiredate,m.fromemp e,bonus bwheree.e name = b.e name这个例子要求优化器按顺序连接在SQL语句的FROM子句中指定的表,在 FROM子句中的第一个表指定了驱动表。ordered提示通常被用来与其它的提示联合起来来保证采用正确的顺序连接多个表。它的用途更多的是在扭转连接表数在四个以上的数据仓库的查询方 面。另外一
8、个例子,下面的查询使用 ordered提示按照指定的顺序来连接表:emp、dept、sal,最后是bon us。我通过指定emp到dept使用哈希连接和 sal到bonus使用嵌套循环连接,来 进一步精炼执行计划。select /*+ ordered use_hash (emp, dept) use_ nl (sal, bonus) */fromemp,dept,sal,bon uswhere .实践建议实际上,更有效率的做法是在产品环境中减小optimizer_max_permutations参数的大小,并且总是使用稳定的优化计划或存储轮廓来防止出现耗时的含有大量连接的查询。一旦找到最佳的连
9、接顺序,您就可以通过增加ordered提示到当前的查询中,并保存它的存储轮廓,来为这些表手工指定连接顺序,从而使其持久化。当你打算使用优化器来稳定计划,则可以照下面的方法使执行计划持久化,临时将 optimizer_search_limit设置为查询中的表的数目,从而允许优化器考虑所有可能的连接顺序。 然后,通过重新编排 WHERE子句中表的名字,并使用 ordered提示,与存储轮廓一起使变 更持久化,来调整查询。在查询中包含四个以上的表时,ordered提示和存储轮廓将排除耗时的评估SQL连接顺序解析的任务,从而提高查询的速度。一旦检测到最佳的连接顺序,我们就可以使用 ordered提示来重载optimizer_search_limit 和optimizer_max_permutations参数。ordered提示要求表按照它们出现在 FROM子句中的顺 序进行连接,所以优化器没有加入描述。作为一个Oracle专业人员,你应该知道在SQL语
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 潜水装备的水下作业安全意识培养与提升考核试卷
- 舞蹈教育在儿童成长中的作用考核试卷
- 窗帘面料的环保染整技术考核试卷
- 四川水利职业技术学院《临床检验仪器与技术》2023-2024学年第二学期期末试卷
- 山西省运城市万荣县2025年初三下学期第二次模拟考试化学试题文试卷含解析
- 山东省威海市文登区文登实验、三里河中学2025届中考化学试题模拟试卷(8)含解析
- 沈阳工业大学《现代地球物理学进展》2023-2024学年第二学期期末试卷
- 潍坊学院《大学写作实践课》2023-2024学年第二学期期末试卷
- 景德镇市重点中学2024-2025学年初三考前热身生物试题试卷含解析
- 天门职业学院《应用真菌学》2023-2024学年第二学期期末试卷
- 2024年度危废培训完整课件
- 2024秋期国家开放大学《可编程控制器应用实训》一平台在线形考(形成任务6)试题及答案
- 《PBR次世代游戏建模技术》(微课版)课件 2低模制作
- 2022年广东省高考数学试卷(新高考I)(含答案)
- 中医四季养生之道课件
- 二下音乐《阿西里西(简谱、五线谱)》公开课课件
- 【涪陵榨菜产品成本控制问题及完善措施分析9600字】
- 公司外派工作合同协议书
- 巾帼家政职业技能竞赛(家政服务)理论考试题库(含答案)
- 终止合作意向书
- CJJT213-2016 生活垃圾卫生填埋场运行监管标准
评论
0/150
提交评论