WEB开发网
开发学院数据库Oracle Oracle数据库中的段管理方式详细介绍 阅读

Oracle数据库中的段管理方式详细介绍

 2007-05-12 12:27:03 来源:WEB开发网   
核心提示:用 Oracle 数据库 10g 通过回收浪费的空间、联机重组表格和评估增长的趋势,有效地在段中进行存储管理,Oracle数据库中的段管理方式详细介绍,近来,有人要求我评估一个与 Oracle 数据库竞争的 RDBMS,Oracle 始终必须从段一直扫描到 HWM,即使它什么也没有发现,在供应商的演示过程中,观众认为&

用 Oracle 数据库 10g 通过回收浪费的空间、联机重组表格和评估增长的趋势,有效地在段中进行存储管理。近来,有人要求我评估一个与 Oracle 数据库竞争的 RDBMS。在供应商的演示过程中,观众认为“最棒”的特性是,对联机重组的支持 — 该产品可以联机重新部署数据块,以使段的等价物更简洁,并且不会影响当前的用户。

那时,Oracle 还没有在 Oracle9i 数据库中提供这种功能。但是现在,有了 Oracle 数据库 10g,就可以轻松地联机回收浪费的空间和压缩对象—正好适合于起步者。

不过,在检验该特性之前,让我们看一看处理这项任务的“传统的”方法。

当前惯例

考虑让我们看一个段,如一张表,其中填满了块,如图 1 所示。在正常操作过程中,删除了一些行,如图 2 所示。现有就有了许多浪费的空间:(i) 在表的上一个末端和现有的块之间,以及 (ii) 在块内部,其中还有一些没有删除的行。

图 1:分配给该表的块。用灰色正方形表示行

Oracle 不会释放空间以供其他对象使用,有一条简单的理由:由于空间是为新插入的行保留的,并且要适应现有行的增长。被占用的最高空间称为最高使用标记 (HWM),如图 2 所示。

图 2:行后面的块已经删除了;HWM 仍保持不变

但是,这种方法有两个主要的问题:

当用户发出一个全表扫描时,Oracle 始终必须从段一直扫描到 HWM,即使它什么也没有发现。该任务延长了全表扫描的时间。

1 2 3 4  下一页

Tags:Oracle 数据库 管理

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接