表碎片起因及解决办法.doc

表碎片起因及解决办法.doc

ID:28586892

大小:29.50 KB

页数:8页

时间:2018-12-11

表碎片起因及解决办法.doc_第1页
表碎片起因及解决办法.doc_第2页
表碎片起因及解决办法.doc_第3页
表碎片起因及解决办法.doc_第4页
表碎片起因及解决办法.doc_第5页
资源描述:

《表碎片起因及解决办法.doc》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、表碎片起因及解决办法跟表碎片有关的基础知识:什么是水线(HighWaterMark)?----------------------------所有的oracle段(segments,在此,为了理解方便,建议把segment作为表的一个同义词)都有一个在段内容纳数据的上限,我们把这个上限称为"highwatermark"或HWM。这个HWM是一个标记,用来说明已经有多少没有使用的数据块分配给这个segment。HWM通常增长的幅度为一次5个数据块,原则上HWM只会增大,不会缩小,即使将表中的数据全部删除,HWM还是为原值,由于这个特点,使HWM很

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

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

4、e='BIG_EMP1';SEGMENT_NAMESEGMENT_TYPEBLOCKSEXTENTS---------------------------------------------------------------BIG_EMP1TABLE102421rowselected.2)SQL>ANALYZETABLEbig_emp1ESTIMATESTATISTICS;Statementprocessed.3)SQL>SELECTtable_name,num_rows,blocks,empty_blocksFROMuser_tablesW

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

6、表的所有的数据库块的数目。USER_TABLES.BLOCKS表示已经使用过的数据库块的数目。4)SQL>SELECTCOUNT(DISTINCTDBMS_ROWID.ROWID_BLOCK_NUMBER(rowid)

7、

8、DBMS_ROWID.ROWID_RELATIVE_FNO(rowid))"Used"FROMbig_emp1;Used----------7001rowselected.5)SQL>DELETEfrombig_emp1;28672rowsprocessed.6)SQL>commit;Statementprocessed.7)

9、SQL>ANALYZETABLEbig_emp1ESTIMATESTATISTICS;Statementprocessed.8)SQL>SELECTtable_name,num_rows,blocks,empty_blocksFROMuser_tablesWHEREtable_name='BIG_EMP1';TABLE_NAMENUM_ROWSBLOCKSEMPTY_BLOCKS--------------------------------------------------------------BIG_EMP107003231rowsel

10、ected.9)SQL>SELECTCOUNT(DISTINCTDBMS_ROWID.ROWID_BLOCK_NUMBER(rowid)

11、

12、DBMS_

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

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

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