为什么AUTOTRACE不会在执行计划中显示分区截断(partitionpruning)?
2008-04-27 02:54
585 查看
The(tm)Users'Co-OperativeFAQ
WhydoesAUTOTRACEnotshowpartitionpruningintheexplainplan?
为什么AUTOTRACE不会在执行计划中显示分区截断(partitionpruning)?
--------------------------------------------------------------------------------
Author'sname:NormanDunbar
作者:NormanDunbar
Author'sEmail:Oracle(at)BountifulSolutions.co.uk
Datewritten: 25 March2004
写作日期:2004年3月25日
Oracleversion(s):9.2.0.3.0
Oracle版本:9.2.0.3.0
WhyisitthatwhenIuseAUTOTRACEinSQL*Plus,theexplainplannevershowspartitionpruningtakingplace?
为什么当我在SQL*Plus中使用AUTOTRACE时,执行计划从不显示发生了分区截断呢?
--------------------------------------------------------------------------------
AUTOTRACEnotshowingpartitionpruning/eliminationisbug1426992,but,afterinvestigationOraclehasdecidedthatthisisnotanoptimiserbug,butabuginSQL*Plus.Youcan,withabitofknowledgeofyourdataandalittleexperimentation,deducethatpartitionpruningistakingplacefromtheoutputofAUTOTRACE,buttherearemucheasierways!
AUTOTRACE不显示分区截断/是错误(BUG)1426992,但调查后Oracle发现这不是优化器的错误,而是SQL*Plus的问题。对数据有所了解并经过一点试验后,你可以根据AUTOTRACE的输出推断出发生了分区截断,但有更简单的方法!
ThefollowingdemonstrationshowsthefailingsinAUTOTRACEanddemonstratesacoupleofothermethodsofdeterminingwhetherornotyourpartitionsarebeingpruned-ornot.
下面的演示显示了AUTOTRACE不能显示时用其他方法判断是否发生了分区截断。
--------------------------------------------------------------------------------
AUTOTRACE
AUTOTRACE
Firstofall,createasimpletablerangepartitionedover6differentpartitions,andfillitwithsometestdataextractedfromALL_OBJECTS.
首先创建一个简单的根据区间分为6个分区(rangepartitioned)的表,并从ALL_OBJECTS填充一些测试数据。
SQL>createtabletab_part(part_keynumber(1),some_textvarchar2(500))
2 partitionbyrange(part_key)(
3 partitionpart_1valueslessthan(2),
4 partitionpart_2valueslessthan(3),
5 partitionpart_3valueslessthan(4),
6 partitionpart_4valueslessthan(5),
7 partitionpart_5valueslessthan(6),
8 partitionpart_6valueslessthan(MAXVALUE));
Tablecreated.
SQL>insert/*+append*/intotab_part
2 selectmod(rownum,10),object_name
3 fromall_objects;
24683rowscreated.
SQL>commit;
Commitcomplete.
Oncethetablehasbeenfilled,analyseitandseehowthedatahasbeenspreadoverthevariouspartitions.Thefirstandlastpartitionshavemoredatainthemthattheremainingfour,hencethedifferingtotals.
一旦表中填入数据,分析并查看数据如何在不同的分区分布。第一和最后的分区比其他四个分区有更多的数据。
SQL>analyzetabletab_partcomputestatistics;
Tableanalyzed.
SQL>selectpartition_name,num_rows
2 fromuser_tab_partitions
3 wheretable_name='TAB_PART'1
WhydoesAUTOTRACEnotshowpartitionpruningintheexplainplan?
为什么AUTOTRACE不会在执行计划中显示分区截断(partitionpruning)?
--------------------------------------------------------------------------------
Author'sname:NormanDunbar
作者:NormanDunbar
Author'sEmail:Oracle(at)BountifulSolutions.co.uk
Datewritten: 25 March2004
写作日期:2004年3月25日
Oracleversion(s):9.2.0.3.0
Oracle版本:9.2.0.3.0
WhyisitthatwhenIuseAUTOTRACEinSQL*Plus,theexplainplannevershowspartitionpruningtakingplace?
为什么当我在SQL*Plus中使用AUTOTRACE时,执行计划从不显示发生了分区截断呢?
--------------------------------------------------------------------------------
AUTOTRACEnotshowingpartitionpruning/eliminationisbug1426992,but,afterinvestigationOraclehasdecidedthatthisisnotanoptimiserbug,butabuginSQL*Plus.Youcan,withabitofknowledgeofyourdataandalittleexperimentation,deducethatpartitionpruningistakingplacefromtheoutputofAUTOTRACE,buttherearemucheasierways!
AUTOTRACE不显示分区截断/是错误(BUG)1426992,但调查后Oracle发现这不是优化器的错误,而是SQL*Plus的问题。对数据有所了解并经过一点试验后,你可以根据AUTOTRACE的输出推断出发生了分区截断,但有更简单的方法!
ThefollowingdemonstrationshowsthefailingsinAUTOTRACEanddemonstratesacoupleofothermethodsofdeterminingwhetherornotyourpartitionsarebeingpruned-ornot.
下面的演示显示了AUTOTRACE不能显示时用其他方法判断是否发生了分区截断。
--------------------------------------------------------------------------------
AUTOTRACE
AUTOTRACE
Firstofall,createasimpletablerangepartitionedover6differentpartitions,andfillitwithsometestdataextractedfromALL_OBJECTS.
首先创建一个简单的根据区间分为6个分区(rangepartitioned)的表,并从ALL_OBJECTS填充一些测试数据。
SQL>createtabletab_part(part_keynumber(1),some_textvarchar2(500))
2 partitionbyrange(part_key)(
3 partitionpart_1valueslessthan(2),
4 partitionpart_2valueslessthan(3),
5 partitionpart_3valueslessthan(4),
6 partitionpart_4valueslessthan(5),
7 partitionpart_5valueslessthan(6),
8 partitionpart_6valueslessthan(MAXVALUE));
Tablecreated.
SQL>insert/*+append*/intotab_part
2 selectmod(rownum,10),object_name
3 fromall_objects;
24683rowscreated.
SQL>commit;
Commitcomplete.
Oncethetablehasbeenfilled,analyseitandseehowthedatahasbeenspreadoverthevariouspartitions.Thefirstandlastpartitionshavemoredatainthemthattheremainingfour,hencethedifferingtotals.
一旦表中填入数据,分析并查看数据如何在不同的分区分布。第一和最后的分区比其他四个分区有更多的数据。
SQL>analyzetabletab_partcomputestatistics;
Tableanalyzed.
SQL>selectpartition_name,num_rows
2 fromuser_tab_partitions
3 wheretable_name='TAB_PART'1
相关文章推荐
- ORA FAQ 性能调整系列之——为什么AUTOTRACE不会在执行计划中显示分区截断(partition pruning)?
- 一个PHP一直执行的例子 不会计划任务可以用这个 PHP+jquery前台动态显示数据库内容
- 10G之后统计信息收集后为什么执行计划不会被立马淘汰
- 为什么我的PHP不显示执行结果?
- 你的计划为什么执行不下去?怎么破?
- SQL Server 执行计划利用统计信息对数据行的预估原理二(为什么复合索引列顺序会影响到执行计划对数据行的预估)
- 你的计划为什么执行不下去?怎么破?
- AutoTRACE是分析SQL的执行计划,执行效率的一个非常简单方便的工具
- 为什么Oracle有时会用索引来查找数据?--强制Oracle使用最优的“执行计划”
- 为什么Oracle有时会用索引来查找数据?--强制Oracle使用最优的“执行计划”
- 看懂PL/SQL执行计划的显示结果
- SQL Server 设置执行计划的显示格式
- Oracle执行计划显示
- mysql定时计划任务,ON COMPLETION [NOT] PRESERVE 当单次计划任务执行完毕后或当重复性的计划任务执行到了ENDS阶段。而声明PRESERVE的作用是使事件在执行完毕后不会被Drop掉
- 显示执行计划的一些方法
- 关于window2008计划任务前台显示和批处理无法正常执行问题的解决办法
- 执行计划中与分区相关的OP介绍
- 似乎知道了为什么网站计数器不会显示/(ASP中FSO的神奇功能)
- Oracle 生成和显示执行计划的方法
- [Oracle]查看SQL的执行计划 - AUTOTRACE,遇到错误ORA-00904: "OTHER_TAG": 标识符无效