Oracle表碎片起因和解决办法

Oracle表碎片起因和解决办法

ID:36381067

大小:43.00 KB

页数:9页

时间:2019-05-10

Oracle表碎片起因和解决办法_第1页
Oracle表碎片起因和解决办法_第2页
Oracle表碎片起因和解决办法_第3页
Oracle表碎片起因和解决办法_第4页
Oracle表碎片起因和解决办法_第5页
资源描述:

《Oracle表碎片起因和解决办法》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、Oracle表碎片起因及解决办法2009-05-1415:42今天发现在一个SQL查询用不到索引,classid是建了索引的,如下:select*frominfobasewhereclassidin(10001,10002,10003,10004,10005);奇怪的发现在classidin(10001,10002)的值两以上就用不索引,两个以下就可以用到,开始怀疑是索引有问题,于是就重建下了下classid上的索引还是不行。从网上找到一篇文章才知道可能是表中存在碎片的问题于是用下面的步骤解决:1、重建表:createtableinfobase2select*

2、frominfobase;2、改以前的表名:altertableinfobaserenametoinfobase3;3、改新建表名为以前表名:altertableinfobase2renametoinfobase;4、建上索引:createindexclassid_indoninfobase(classid);可是过了一天问题又出现了,索引又是不能使用了,然后执行下面的语句解决:ANALYZETABLEINFOBASEcompute  Statistics;或是ANALYZETABLEINFOBASEestimate  STATISTICSSAMPLE50PE

3、RCENT;--注意:50PERCENT值太小索引可能还是不起作用,我就开始用20PERCENT时,索引还是用不上。跟表碎片有关的基础知识:什么是水线(HighWaterMark)?----------------------------所有的oracle段(segments,在此,为了理解方便,建议把segment作为表的一个同义词)都有一个在段内容纳数据的上限,我们把这个上限称为"highwatermark"或HWM。这个HWM是一个标记,用来说明已经有多少没有使用的数据块分配给这个segment。HWM通常增长的幅度为一次5个数据块,原则上HWM只会增大

4、,不会缩小,即使将表中的数据全部删除,HWM还是为原值,由于这个特点,使HWM很象一个水库的历史最高水位,这也就是HWM的原始含义,当然不能说一个水库没水了,就说该水库的历史最高水位为0。但是如果我们在表上使用了truncate命令,则该表的HWM会被重新置为0。HWM数据库的操作有如下影响:a)全表扫描通常要读出直到HWM标记的所有的属于该表数据库块,即使该表中没有任何数据。b)即使HWM以下有空闲的数据库块,键入在插入数据时使用了append关键字,则在插入时使用HWM以上的数据块,此时HWM会自动增大。如何知道一个表的HWM?a)首先对表进行分析:ANA

5、LYZETABLEESTIMATE/COMPUTESTATISTICS;b)SELECTblocks,empty_blocks,num_rowsFROMuser_tablesWHEREtable_name=;BLOCKS列代表该表中曾经使用过得数据库块的数目,即水线。EMPTY_BLOCKS代表分配给该表,但是在水线以上的数据库块,即从来没有使用的数据块。让我们以一个有28672行的BIG_EMP1表为例进行说明:1)SQL>SELECTsegment_name,segment_type,blocksFROMdba_

6、segmentsWHEREsegment_name='BIG_EMP1';SEGMENT_NAMESEGMENT_TYPEBLOCKSEXTENTS---------------------------------------------------------------BIG_EMP1TABLE102421rowselected.2)SQL>ANALYZETABLEbig_emp1ESTIMATESTATISTICS;Statementprocessed.3)SQL>SELECTtable_name,num_rows,blocks,empty_blocks

7、FROMuser_tablesWHEREtable_name='BIG_EMP1';TABLE_NAMENUM_ROWSBLOCKSEMPTY_BLOCKS--------------------------------------------------------------BIG_EMP1286727003231rowselected.注意:BLOCKS+EMPTY_BLOCKS(700+323=1023)比DBA_SEGMENTS.BLOCKS少个数据库块,这是因为有一个数据库块被保留用作segmentheader。DBA_SEGMENTS.BLOCK

8、S表示分配给这个表的所有的数据库块的数

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。