为什么AUTOTRACE不会在执行计划中显示分区截断(partitionpruning)?

<script type="text/javascript"> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
<script type="text/javascript"> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>

The(tm)Users'Co-OperativeFAQ
Whydoes AUTOTRACEnotshowpartitionpruningintheexplainplan?
为什么 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
WhyisitthatwhenIuse AUTOTRACEinSQL*Plus,theexplainplannevershowspartitionpruningtakingplace?
为什么当我在SQL*Plus中使用 AUTOTRACE时,执行计划从不显示发生了分区截断呢?

 

--------------------------------------------------------------------------------

AUTOTRACEnotshowingpartitionpruning/eliminationisbug1426992,but,afterinvestigationOraclehasdecidedthatthisisnotanoptimiserbug,butabuginSQL*Plus.Youcan,withabitofknowledgeofyourdataandalittleexperimentation,deducethatpartitionpruningistakingplacefromtheoutputof AUTOTRACE,buttherearemucheasierways!
AUTOTRACE不显示分区截断/是错误(BUG)1426992,但调查后Oracle发现这不是优化器的错误,而是SQL*Plus的问题。对数据有所了解并经过一点试验后,你可以根据 AUTOTRACE的输出推断出发生了分区截断,但有更简单的方法!
Thefollowingdemonstrationshowsthefailingsin AUTOTRACEanddemonstratesacoupleofothermethodsofdeterminingwhetherornotyourpartitionsarebeingpruned-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 <script type="text/javascript"> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
<script type="text/javascript"> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值