图 1 :分配给该表的块。用灰色正方形表示行。 Oracle 不会释放空间以供其他对象使用,有一条简单的理由:由于空间是为新插入的行保留的,并且要适应现有行的增长。被占用的最高空间称为最高使用标记 (HWM) ,如图 2 所示。
图 2 :行后面的块已经删除了; HWM 仍保持不变。 但是,这种方法有两个主要的问题:
图 3 :重组行后的表中的块。 在执行该操作后,让我们看一看空间利用率所发生的改变。使用在第一步展示的 PL/SQL 块,可以看到块现在是如何组织的: FS1 Blocks = 0 Bytes = 0 FS2 Blocks = 0 Bytes = 0 FS3 Blocks = 1 Bytes = 0 FS4 Blocks = 0 Bytes = 0 Full Blocks = 2 Bytes = 16384 注重这里的重要改变: FS4 块(具有 75-100% 的空闲空间)的数量现在从 4,148 降为 0 。我们还看到 FS3 块(具有 50-75% 的空闲空间)的数量从 0 增加到 1 。但是,由于 HWM 没有被重置,总的空间利用率仍然是相同的。我们可以用如下命令检查使用的空间: SQL> select blocks from user_segments where segment_name = 'BOOKINGS'; BLOCKS --------- 4224 由该表占用的块的数量 (4,224) 仍然是相同的,这是因为并没有把 HWM 从其原始位置移开。可以把 HWM 移动到一个较低的位置,并用如下命令回收空间: alter table bookings shrink space; 注重子句 COMPACT 没有出现。该操作将把未用的块返回给数据库并重置 HWM 。可以通过检查分配给表的空间来对其进行测试: SQL> select blocks from user_segments where segment_name = 'BOOKINGS'; BLOCKS ---------- 8 块的数量从 4,224 降为 8 ;该表内所有未用的空间都返回给表空间,以让其他段使用,如图 4 所示。
图 4 :在收缩后,把空闲块返回给数据库。 这个收缩操作完全是在联机状态下发生的,并且不会对用户产生影响。 也可以用一条语句来压缩表的索引: alter table bookings shrink space cascade; 联机 shrink 命令是一个用于回收浪费的空间和重置 HWM 的强大的特性。我把后者(重置 HWM )看作该命令最有用的结果,因为它改进了全表扫描的性能。 找到收缩合适选择 在执行联机收缩前,用户可能想通过确定能够进行最完全压缩的段,以找出最大的回报。只需简单地使用 dbms_space 包中的内置函数 verify_shrink_candidate 。假如段可以收缩到 1,300,000 字节,则可以使用下面的 PL/SQL 代码进行测试: begin if (dbms_space.verify_shrink_candidate ('ARUP','BOOKINGS','TABLE',1300000) then :x := 'T'; else :x := 'F'; end if; end; 新闻热点
疑难解答