oracle的高水位线(HWM)

现在解释下什么是“高水位”:

  oracle的逻辑存储结构:表空间——>段——>区——>块

  块:是粒度最小的存储单位,现在标准的块大小是8K,ORACLE每一次I/O操作也是按块来操作的,也就是说当ORACLE从数据文件读数据时,是读取多少个块,而不是多少行.

  区:由一系列相邻的块而组成,这也是ORACLE空间分配的基本单位,举个例子来说,当我们创建一个表A时,首先ORACLE会分配一区的空间给这个表,随着不断的INSERT数据到A,原来的这个区容不下插入的数据时,ORACLE是以区为单位进行扩展的,也就是说再分配多少个区给A,而不是多少个块.

  段:是由一系列的区所组成,一般来说,当创建一个对象时(表,索引),就会分配一个段给这个对象.所以从某种意义上来说,段就是某种特定的数据.如CREATE TABLE PM_USER,这个段就是数据段,而CREATE INDEX ON PM_USER(NAME),ORACLE同样会分配一个段给这个索引,但这是一个索引段了.查询段的信息可以通过数据字典: SELECT * FROM USER_SEGMENTS来获得,

  表空间:包含段,区及块.表空间的数据物理上储存在其所在的数据文件中.一个数据库至少要有一个表空间.

  所有的oracle段都有一个在段内容纳数据的上限,我们把这个上限称为"high water mark"或HWM。这个HWM是一个标记,用来说明已经有多少没有使用的数据块分配给这个segment。

  HWM通常增长的幅度为一次5个数据块,原则上HWM只会增大,不会缩小,即使将表中的数据全部删除,HWM还是为原值,由于这个特点,使HWM很象一个水库的历史最高水位,这也就是HWM的原始含义,当然不能说一个水库没水了,就说该水库的历史最高水位为0。但是如果我们在表上使用了truncate命令,则该表的HWM会被重新置为0。

  如何知道一个表的HWM?

  a) 首先对表进行分析:

  ANALYZE TABLE ESTIMATE/COMPUTE STATISTICS;

  b) 查看相关信息:

  SELECT blocks, empty_blocks, num_rows FROM user_tables WHERE table_name =;

  [SYS@orcl] SQL>select segment_name,segment_type,blocks from dba_segments where segment_name=’A’;

  SEGMENT_NAME SEGMENT_TYPE BLOCKS

  ------------ ------------ -------

  A                  TABLE      8

  可得到A表分配了8个blocks。

  [TEST1@orcl] SQL>analyze table a compute statistics;

  表已分析。

  [TEST1@orcl] SQL>select num_rows,blocks,empty_blocks from user_tables where table_name=’A’;

  NUM_ROWS     BLOCKS EMPTY_BLOCKS

  ---------- ---------- ------------

  1          5            3

  BLOCKS 列代表该表中曾经使用过得数据库块的数目,即水线。EMPTY_BLOCKS 代表分配给该表,但是在水线以上的数据库块,即从来没有使用的数据块.

  [TEST1@orcl] SQL>delete from a;

  [TEST1@orcl] SQL>analyze table a compute statistics;

  表已分析。

  [TEST1@orcl] SQL>select num_rows,blocks,empty_blocks from user_tables where table_name=’A’;

  NUM_ROWS     BLOCKS EMPTY_BLOCKS

  ---------- ---------- ------------

  0          5            3

  [TEST1@orcl] SQL>select count(distinct dbms_rowid.rowid_block_number(rowid)||

  2 dbms_rowid.rowid_relative_fno(rowid)) "used" from a;

  used

  ----------

  0    注:Used = 0 这表名没有任何数据库块容纳数据,即表中无数据

  [TEST1@orcl] SQL>truncate table a;

  表被截断。

  [TEST1@orcl] SQL>analyze table a compute statistics;

  表已分析。

  [TEST1@orcl] SQL>select table_name,blocks,empty_blocks from user_tables where table_name=’A’;

  TABLE_NAME     BLOCKS EMPTY_BLOCKS

  ---------- ---------- ------------

  A                   0            8

  注意:TRUNCATE命令回收了由delete命令产生的空闲空间。假如表原有1024块,使用TRUNCATE后该表分配的空间降为512块。为了保留由delete命令产生的空闲空间,可以使用TRUNCATE TABLE TEST REUSE STORAGE用此命令后,该表还会是原先的1024块。

    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

  6. 修正ORACLE表的高水位线

  在ORACLE中,执行对表的删除操作不会降低该表的高水位线。而全表扫描将始终读取一个段(extent)中所有低于高水位线标记的块。如果在执行删除操作后不降低高水位线标记,则将导致查询语句的性能低下。

  下面的方法都可以降低高水位线标记。

  (1). 执行表重建指令 alter table table_name move;

  在线转移表空间ALTER TABLE ... MOVE TABLESPACE ..

  当你创建了一个对象如表以后,不管你有没有插入数据,它都会占用一些块,ORACLE也会给它分配必要的空间.同样,用ALTER TABLE MOVE释放自由空间后,还是保留了一些空间给这个表.

  ALTER TABLE ... MOVE 后面不跟参数也行,不跟参数表还是在原来的表空间,Move后记住重建索引。如果以后还要继续向这个表增加数据,没有必要move,只是释放出来的空间,只能这个表用,其他的表或者segment无法使用该空间。

  (2). 执行alter table table_name shrink space;

  注意,此命令为Oracle 10g新增功能,再执行该指令之前必须允许行移动 alter table table_name enable row movement;

  如果要同时压缩表的索引:ALTER TABLE TEST_TAB SHRINK SPACE CASCADE

  (3). 复制要保留的数据到临时表t,drop原表,然后rename临时表t为原表

  (4). 用逻辑导入导出: Emp/Imp

  (5). Alter table table_name deallocate unused

  注:这证明,DEALLOCATE UNUSED为释放HWM上面的未使用空间,但是并不会释放HWM下面的自由空间,也不会移动HWM的位置.

  (6). 尽量使用truncate.

 

SQL> truncate table c;

Table truncated.

SQL> select blocks,empty_blocks,num_rows from user_tables where table_name='C';

    BLOCKS EMPTY_BLOCKS   NUM_ROWS
---------- ------------ ----------
         2            5          0

SQL> analyze table c compute statistics;

Table analyzed.

SQL> select blocks,empty_blocks,num_rows from user_tables where table_name='C';

    BLOCKS EMPTY_BLOCKS   NUM_ROWS
---------- ------------ ----------
         0            7          0

 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/13024285/viewspace-629842/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/13024285/viewspace-629842/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值