- 1、本文档共16页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
oracle为一个sql钉上执行计划
日常开发活动中,有时候需要对oracle执行计划进行监控,以此来调优程序和数据库方面的性能。 常用方法有以下几种: 一、通过PL/SQLDev工具 1、直接File-New-ExplainPlanWindow,在窗口中执行sql可以查看计划结果。其中,Cost表示cpu的消耗,单位为n%,Cardinality表示执行的行数,等价Rows。 2、先执行EXPLAINPLANFORselect*fromtableAwhereparaA=1,再select*fromtable(DBMS_)便可以看到oracle的执行计划了,看到的结果和1中的一样,所以使用工具的时候推荐使用1方法。 注意:PL/SQLDev工具的Commandwindow中不支持setautotranceon的命令。还有使用工具方法查看计划看到的信息不全,有些时候我们需要sqlplus的支持。 二、通过sqlplus 1、一般情况都是本机链接远程服务器,所以命令如下: sqlplususer/pwd@serviceName 此处的serviceName为中定义的命名空间。 2、执行setautotraceon,然后执行sql语句,会列出以下信息: 。。。 统计信息 ---------------------------------------------------------- 1recursivecalls 0dbblockgets 2consistentgets 0physicalreads 0redosize(重做数——执行SQL的过程中,产生的重做日志的大小)358bytessentviaSQL*Nettoclient 366bytesreceivedviaSQL*Netfromclient 1SQL*Netroundtripsto/fromclient 0sorts(memory)在内存中发生的排序 0sorts(disk)在硬盘中发生的排序 1rowsprocessed 省略部分信息和通过PL/SQLDev工具查看执行计划的信息一样,下面的统计信息是更详细的。 判断SQL效率高低不关通过时间来衡量,还应该通过执行SQL执行状态里面的逻辑读的数量 逻辑读= 1、SETAUTOTRACEONEXPLAIN SQLexecdbms__table_stats(USER,表,METHOD_OPT=FORALLCOLUMNSSIZE100) 4、AUTOTRACE的几个常用选项 setautotraceoff----------------不生成autotrace报告,这是缺省模式setautotraceonexplain------autotrace只显示优化器执行路径报告setautotraceonstatistics--只显示执行统计信息 setautotraceon-----------------包含执行计划和统计信息 setautotracetraceonly------同setautotraceon,但是不显示查询输 (1).setautotraceonexplain;--只显示执行计划 SQLsetautotraceonexplain; SQLselectcount(*)fromdba_objects;COUNT(*) 31820 ExecutionPlan ---------------------------------------------------------- 0SELECTSTATEMENTOptimizer=CHOOSE 10SORT(AGGREGATE) 21VIEWOFDBA_OBJECTS 32UNION-ALL 43FILTER 54TABLEACCESS(BYINDEXROWID)OFOBJ$ 65NESTEDLOOPS 76TABLEACCESS(FULL)OFUSER$ 86INDEX(RANGESCAN)OFI_OBJ2(UNIQUE) 94TABLEACCESS(BYINDEXROWID)OFIND$ 109INDEX(UNIQUESCAN)OFI_IND1(UNIQUE) 113NESTEDLOOPS 1211TABLEACCESS(FULL)OFUSER$ 1311INDEX(RANGESCAN)OFI_LINK1(NON-UNIQUE) (2).setautotraceonstatistics;--只显示统计信息 SQLsetautotraceon
您可能关注的文档
最近下载
- 餐饮值班管理课程培训.pptx
- 尔雅《批判与创意思考》课后习题+期末试题.docx VIP
- 6-4正奇租赁二期资产支持专项计划现金流预测分析报告1213日.pdf
- 算法设计与分析(北航)中国大学MOOC慕课 章节测验期末考试客观题答案.docx
- 2024年山东省济宁市中考化学试卷(附答案).docx VIP
- T IAC CAMRA 50-2024 《事故汽车常用零部件修复与更换判别规范》(2).pdf
- 北师大版数学八年级下册第六章 平行四边形 大单元整体教学设计学历案教案附作业设计(基于新课标教学评一致性).docx
- 长江经济带港口发展研究(2011~).docx VIP
- 染色技术 8.1 涤纶结构特点和分散染料分类 8.1 涤纶结构特点、分散染料分类.pptx
- 人教版三年级下册必读书目《中国古代寓言故事》 .pdf
文档评论(0)