日常监控免不了监控表空间空闲信息,但是有时发现查询他非常缓慢,这是因为dba_free_space 里面条目过多,所以查询起来非常缓慢,为啥这个view里面条目如此
之多呢,有时候会发现里面的extent居然还是连续的, 其实这是因为drop 对象造成的,下面的例子可以展示一下这个场景:
create table t1 as select * from dba_tables where rownum<1000;
create table t2 as select * from dba_tables where rownum<1000;
分别新建两个表,然后查询他们的extent情况
select * from dba_extents where segment_NAME IN (‘T1′,’T2’)
MAOB T1 TABLE USERS 0 4 520 65536 8 4
MAOB T1 TABLE USERS 1 4 528 65536 8 4
MAOB T1 TABLE USERS 2 4 536 65536 8 4
MAOB T1 TABLE USERS 3 4 7184 65536 8 4
MAOB T1 TABLE USERS 4 4 7192 65536 8 4
MAOB T1 TABLE USERS 5 4 7200 65536 8 4
MAOB T2 TABLE USERS 0 4 7208 65536 8 4 <<T2 是接着T1的最后一个extent分配的
MAOB T2 TABLE USERS 1 4 7216 65536 8 4
MAOB T2 TABLE USERS 2 4 7224 65536 8 4
MAOB T2 TABLE USERS 3 4 7232 65536 8 4
MAOB T2 TABLE USERS 4 4 7240 65536 8 4
MAOB T2 TABLE USERS 5 4 7248 65536 8 4
对两个表进行drop 之后,我们查询 dba_free_space情况
select * from dba_free_space where file_id=4 order by block_id
USERS 4 520 65536 8 4
USERS 4 528 65536 8 4
USERS 4 536 65536 8 4 <<<以上3个是T1的前三个extent 都是连续的,并没有进行合并
USERS 4 640 41943040 5120 4
USERS 4 7184 65536 8 4
USERS 4 7192 65536 8 4
USERS 4 7200 65536 8 4 <<<以上3个是T1的后三个extent 都是连续的,并没有进行合并
USERS 4 7208 65536 8 4
USERS 4 7216 65536 8 4
USERS 4 7224 65536 8 4
USERS 4 7232 65536 8 4
USERS 4 7240 65536 8 4
USERS 4 7248 65536 8 4 <<以上6个是T2的extent,都是连续的,并没有进行合并
USERS 4 7256 524288 64 4 <<这个和T2的extents是连续的,但是也没有合并
这些extents都是保持原样的出现在了dba_free_space,所以造成条目增多,我们接下来进行purge
purge recyclebin;
我们再次查询 dba_free_space情况 select * from dba_free_space where file_id=4 order by block_id
USERS 4 520 196608 24 4 <<3个extent 已经合并成一个24blocks的新extent
USERS 4 640 41943040 5120 4
USERS 4 7184 1114112 136 4 <<6个extent 共计72个block连同原有的相邻extent 里面的64 个block合并成为了一个新的136block的extent
dba_free_space条目也大幅减少,所以对于recyclebin里面有着大量drop的表,尤其是这些表曾经分配了大量的extent,就会出现此类问题。