HWM的一些特性
1 oracle用HWM来界定一个段中使用的块和未使用的块。
当我们创建一个表:A时,ORACLE就会为这个对象分配一个段.在这个段中,即使我们未插入任何记录,也至少有一个区(64bit,也就是8个块)被分配,第一个区的第一个块就称为段头(SEGMENT HEADE),段头中就储存了一些信息,基中HWM的信息就存储在此.此时,因为第一个区的第一块用于存储段头的一些信息,虽然没有存储任何实际的记录,但也算是被使用,此时HWM是位于第2个块.当我们不断插入数据到A后,第1个块已经放不下后面新插入的数据,此时,ORACLE将高水位之上的块用于存储新增数据,同时,HWM本身也向上移.也就是说,当我们不断插入数据时,HWM会不断上移,这样,在HWM之下的,就表示使用过的块,HWM之上的就表示已分配但从未使用过的块.
2 HWM在插入数据时,当现有空间不足而进行空间的扩展时会向上移,但删除数据时不会往下移.
这就好比是水库的水位,当涨水时,水位往上移,当水退出后,最高水位的痕迹还是清淅可见.
删除数据后便存在浪费的空间,ORACLE 不会释放空间以供其他对象使用,有一条简单的理由:由于空间是为新插入的行保留的,并且要适应现有行的增长。被占用的最高空间称为最高使用标记 (HWM)。
3 HWM的信息存储在段头当中.
HWM本身的信息是储存在段头.在段空间是手工管理方式时,ORACLE是通过FREELIST(一个单向链表)来管理段内的空间分配.在段空间是自动管理方式时(ASSM),ORACLE是通过BITMAP来管理段内的空间分配.
4 ORACLE的全表扫描是读取高水位标记(HWM)以下的所有块
当用户发出一个全表扫描时,ORACLE 始终必须从段一直扫描到 HWM,即使它什么也没有发现。该任务延长了全表扫描的时间。
采用TRUNCATE语句删除一个表的数据的时候,类似于重新建立了表,不仅把数据都删除了,还把HWM给清空恢复为0。
5 当用直接路径插入行时 — 例如,通过直接加载插入(用 APPEND 提示插入)或通过 SQL*LOADER 直接路径 — 数据块直接置于 HWM 之上。它下面的空间就浪费掉了
在手动段空间管理(Manual Segment Space Management)中,段中只有一个HWM,但是在Oracle 9i Release1才添加的自动段空间管理(Automatic Segment Space Management)中,又有了一个低HWM的概念出来。为什么有了HWM还又有一个低HWM呢,这个是因为自动段空间管理的特性造成的。在手段段空间管理中,当数据插入以后,如果是插入到新的数据块中,数据块就会被自动格式化等待数据访问。而在自动段空间管理中,数据插入到新的数据块以后,数据块并没有被格式化,而是在第一次访问这个数据块的时候才格式化这个块。所以我们又需要一条水位线,用来标示已经被格式化的块。这条水位线就叫做低HWM。一般来说,低HWM肯定是低于等于HWM的。
额外扩展:
[TEST1@orcl] SQL>delete from c;
[TEST1@orcl] SQL>alter table c shrink space;
alter table c shrink space
*
第 1 行出现错误:
ORA-10636: ROW MOVEMENT is not enabled
[TEST1@orcl] SQL>alter table c enable row movement;
表已更改。
[TEST1@orcl] SQL>alter table c shrink space;
表已更改。
[TEST1@orcl] SQL>analyze table c compute statistics;
[TEST1@orcl] SQL>select table_name,blocks,empty_blocks from user_tables where table_name='C';
TABLE_NAME BLOCKS EMPTY_BLOCKS
---------- ---------- ------------
C 1 7
分享到:
相关推荐
Oracle数据库中的“高水位”(High Water Mark, HWM)是表空间管理的一个关键概念,它对于数据库的性能和空间利用率有着深远的影响。本文将深入解析高水位的概念、作用,以及如何调整以优化存储效率。 高水位(HWM...
在 Oracle 数据的存储中,可以把存储空间想象为一个水库,数据想象为水 库中的水。水库中的水的位置有一条线叫做水位线,在 Oracle 中,这条线被称为`高水位线(High-warter mark, HWM)
其中,“高水位”(High Water Mark,简称HWM)是Oracle数据库中的一个重要概念,它与表空间、段、区和块等存储结构密切相关。本篇文章将深入探讨Oracle高水位的概念、作用以及其在数据库操作中的影响。 高水位...
Oracle 高水位线(High Water Mark,HWM)是 Oracle 段中一个重要的概念,它标志着段中已经使用的数据块的上限。在 Oracle 中,每个段(包括表、索引等)都有一个高水位线,用于记录该段已经使用的数据块的数量。 ...
对于DB2数据库管理(DMS)表空间的高水位标记(HWM)是指该表空间曾经使用到的最大数据页数。如果使用:db2 list tablespaces show detail,看到某个DMS表空间的已用页数低于高水位标记,则有可能通过如下方法降低高...
在Oracle数据库中,“高水位”(High Water Mark,HWM)是一个非常重要的概念。它标记了数据表中最后一次插入、更新或删除操作的位置。简单来说,高水位线以下的空间是已经被使用过的空间,而高水位线以上的空间则是...
Oracle的Freelist(自由列表)和HWM(高水位线)是数据库管理中的关键概念,它们直接影响到数据存储的效率和SQL查询性能。本文将深入解析这两个概念及其原理,并探讨相关的性能优化策略。 首先,Oracle的Freelist是...
【HWM14高层大气风场模式】是用于模拟和预测地球高层大气风场的模型,它是HWM(水平风场模型)系列的最新发展。HWM系列模型自上世纪70年代以来一直被广泛应用于空间天气研究和预报,对理解和预测空间环境中的动态...
在数据库管理中,特别是在Oracle这样的关系型数据库管理系统中,随着表中数据的不断增长,表的“高水位”(High Water Mark,简称HWM)也会随之提升。当HWM达到一定程度后,它可能会对表上的SQL查询效率产生负面影响...
中性大气风场模型,简称HWM,是地球物理学中用于描述在中性大气层(即非电离层)内风速和风向分布的重要理论工具。HWM14是2014年更新的一个版本,它为科学家和工程师提供了计算中性大气风场速度的方法,是气象学、...
内容表空间高水位标记(HWM)为什么要降低高水位标记在9.7以前如何降低高水位标记9.7降低高水位标记的新功能总结参考资料表空间高水位标记(HWM)高水位标记是一个应用广泛的术语,在很多的场合都会使用到,一般用以...
在Oracle数据库中,高水位(High Water Mark, HWM)是衡量表数据存储位置的一个关键概念。它标识了表中数据曾经达到的最高存储位置。每当向表中插入、更新或删除数据时,Oracle数据库会自动管理数据的存储位置。值得...
【MBUS电源线通信模块详解】 MBUS(Meter Bus)是一种广泛应用在公用事业领域的低速数据通信协议,尤其适用于电能、水、气等表计的远程读取。标题中的"HWM_MBUS-M13_1.08_EN_mbus_"暗示这是一款名为HWM的MBUS-M13...
hwm
High Water Mark(HWM)是Oracle段内的一条虚拟线,表示段中已分配的最高数据边界。一旦数据写入超过了HWM,Oracle会在段的下一个区分配新的空间。HWM与SQL性能紧密相关,因为它影响了数据扫描的效率。如果数据集中...
在讨论Oracle 10g中的高水位标记(HWM)原理及性能优化策略之前,我们首先要了解HWM是什么以及它在Oracle数据库中的作用。HWM是Oracle数据库中用于区分数据段中已使用块和未使用块的界限。在全表扫描操作中,Oracle...
总的来说,"840dsl" 可能是一个高性能的DSL调制解调器型号,而 "HWM" 是相关硬件的制造商。要了解更多关于这个设备的详细信息,需要进一步探索提供的压缩包内容,或者寻找更多上下文信息。如果你遇到任何问题,如...
Python中的HWM93 Python≥3.6的NASA水平风模型HWM93 适用于许多Fortran编译器,包括: Gfortran≥5 英特尔ifort PGI pgf90 Nvidia flang 安装 需要诸如gfortran类的Fortran编译器。 我们使用f2py ( numpy一...