oracle的HWM

HWM介绍

HWM(硬件监视):(Hard Ware Monitoring)。它就象一个监视器,随时侦测系统硬件的物理状态,看是否出现超负荷或其它潜在的不稳定因素,如电源风扇是否停转、电源是否稳定、芯片温度是否超过额定值等。一旦其中某项出现问题,HWM将立即提醒用户结束当前任务。这样就可避免因突然 死机而造成不必要的损失。
HWM(高水位线)(High Water Mark):是数据库段管理中的一个重要概念,简单来说HWM就是在段中已经使用和没有使用的块的分界线。在oracle请求空间的时候,如果现有的Freelist中没有足够的空间时,HWM指向的块将被标记为已使用并且HWM将移动到下一个未使用的块。
附注:

编辑本段HWM 特点

⒈ ORACLE用HWM来界定一个段中使用的块和未使用的块.
举个例子来说,当我们创建一个表时,ORACLE就会为这个对象分配一个段.在这个段中,即使我们未插入任何记录,也至少有一个区被分配,第一个区的第一个块就称为段头(SEGMENT HEADE),段头中就储存了一些信息,基中HWM的信息就存储在此.此时,因为第一个区的第一块用于存储段头的一些信息,虽然没有存储任何实际的记录,但也算是被使用,此时HWM是位于第2个块.当我们不断插入数据到表后,第1个块已经放不下后面新插入的数据,此时,ORACLE将高水位之上的块用于存储新增数据,同时,HWM本身也向上移.也就是说,当我们不断插入数据时,HWM会往不断上移,这样,在HWM之下的,就表示使用过的块,HWM之上的就表示已分配但从未使用过的块.
⒉ HWM在插入数据时,当现有空间不足而进行空间的扩展时会向上移,但删除数据时不会往下移.
这就好比是水库的水位,当涨水时,水位往上移,当水退出后,最高水位的痕迹还是清淅可见.
ORACLE 不会释放空间以供其他对象使用,有一条简单的理由:由于空间是为新插入的行保留的,并且要适应现有行的增长。被占用的最高空间称为最高使用标记 (HWM),
⒊ HWM的信息存储在段头当中.
HWM本身的信息是储存在段头.在段空间是手工管理方式时,ORACLE是通过FREELIST(一个 单向链表)来管理段内的空间分配.在段空间是自动管理方式时(ASSM),ORACLE是通过BITMAP来管理段内的空间分配.
⒋ ORACLE的 全表扫描是读取高水位标记(HWM)以下的所有块.
所以问题就产生了.当用户发出一个 全表扫描时,ORACLE 始终必须从段一直扫描到 HWM,即使它什么也没有发现。该任务延长了 全表扫描的时间。
⒌ 当用直接路径插入行时,即使HWM以下有空闲的数据库块,键入在插入数据时使用了append 关键字,则在插入时使用HWM以上的 数据块,此时HWM会自动增大。
例如,通过直接加载插入(用 APPEND 提示插入)或通过 SQL*LOADER 直接路径   数据块直接置于 HWM 之上。它下面的空间就浪费掉了。

你可能感兴趣的:(oracle,hwm)