ORACLE水位线HWM

参考http://www.cnblogs.com/husam/p/6604437.html很详细


说到HWM,我们首先要简要的谈谈ORACLE的逻辑存储管理.我们知道,ORACLE在逻辑存储上分4个粒度:表空间,段,区和块. 
 
(1)块:是粒度最小的存储单位,现在标准的块大小是8K,ORACLE每一次I/O操作也是按块来操作的,也就是说当ORACLE从数据文件读数据时,是读取多少个块,而不是多少行. 
 
(2)区:由一系列相邻的块而组成,这也是ORACLE空间分配的基本单位,举个例子来说,当我们创建一个表PM_USER时,首先ORACLE会分配一区的空间给这个表,随着不断的INSERT数据到PM_USER,原来的这个区容不下插入的数据时,ORACLE是以区为单位进行扩展的,也就是说再分配多少个区给PM_USER,而不是多少个块.  
 
(3)段:是由一系列的区所组成,一般来说,当创建一个对象时(表,索引),就会分配一个段给这个对象.所以从某种意义上来说,段就是某种特定的数据.如CREATE TABLE PM_USER,这个段就是数据段,而CREATE INDEX ON PM_USER(NAME),ORACLE同样会分配一个段给这个索引,但这是一个索引段了.查询段的信息可以通过数据字典: SELECT * FROM USER_SEGMENTS来获得,
 
(4)表空间:包含段,区及块.表空间的数据物理上储存在其所在的数据文件中.一个数据库至少要有一个表空间.
 
OK,我们现在回到HWM上来,那么,什么是高水位标记呢?这就跟ORACLE的段空间管理相关了.
 
 
(一)ORACLE用HWM来界定一个段中使用的块和未使用的块.

举个例子来说,当我们创建一个表:PT_SCHE_DETAIL时,ORACLE就会为这个对象分配一个段.在这个段中,即使我们未插入任何记录,也至少有一个区被分配,第一个区的第一个块就称为段头(SEGMENT HEADE),段头中就储存了一些信息,基中HWM的信息就存储在此.此时,因为第一个区的第一块用于存储段头的一些信息,虽然没有存储任何实际的记录,但也算是被使用,此时HWM是位于第2个块.当我们不断插入数据到PM_USER后,第1个块已经放不下后面新插入的数据,此时,ORACLE将高水位之上的块用于存储新增数据,同时,HWM本身也向上移.也就是说,当我们不断插入数据时,HWM会往不断上移,这样,在HWM之下的,就表示使用过的块,HWM之上的就表示已分配但从未使用过的块.
 
(二)HWM在插入数据时,当现有空间不足而进行空间的扩展时会向上移,但删除数据时不会往下移.
 
这就好比是水库的水位,当涨水时,水位往上移,当水退出后,最高水位的痕迹还是清淅可见.
考虑让我们看一个段,如一张表,其中填满了块,如图 1 所示。在正常操作过程中,删除了一些行,如图 2 所示。现有就有了许多浪费的空间:(I) 在表的上一个末端和现有的块之间,以及 (II) 在块内部,其中还有一些没有删除的行。
 
HWM01
图1:分配给该表的块。用灰色正方形表示行
 
ORACLE 不会释放空间以供其他对象使用,有一条简单的理由:由于空间是为新插入的行保留的,并且要适应现有行的增长。被占用的最高空间称为最高使用标记 (HWM),如图 2 所示。
 
HWM02 
图2:行后面的块已经删除了;HWM 仍保持不变
 
(三)HWM的信息存储在段头当中.

HWM本身的信息是储存在段头.在段空间是手工管理方式时,ORACLE是通过FREELIST(一个单向链表)来管理段内的空间分配.在段空间是自动管理方式时(ASSM),ORACLE是通过BITMAP来管理段内的空间分配.
 
(四)ORACLE的全表扫描是读取高水位标记(HWM)以下的所有块.
 
所以问题就产生了.当用户发出一个全表扫描时,ORACLE 始终必须从段一直扫描到 HWM,即使它什么也没有发现。该任务延长了全表扫描的时间。
 
(五)当用直接路径插入行时 — 例如,通过直接加载插入(用 APPEND 提示插入)或通过 SQL*LOADER 直接路径 — 数据块直接置于 HWM 之上。它下面的空间就浪费掉了。
 
我们来分析这两个问题,后者只是带来空间的浪费,但前者不仅是空间的浪费,而且会带来严重的性能问题

Oracle数据库中,高水位线(High Water Mark,HWM)是指数据块在最后一次更新后尚未同步到日志的最新位置。当你尝试读取或更新一个数据块时,如果它的HWM高于当前redo log的位置,那么就需要先应用redo logs才能获取最新的数据状态。以下是查询段的HWM的一些常用方法: 1. **查看单个空间的数据块HWM**: 使用`DBA_DATA_FILES`视图可以查看数据文件的信息,其中包括HWM: ```sql SELECT file_id, block_number, hwm_block_number FROM dba_data_files WHERE file_name = 'YOUR_FILE_NAME'; ``` 将`YOUR_FILE_NAME`替换为你要查询的具体数据文件名。 2. **查询整个段的HWM**: 对于指定的用户空间下的段,可以使用`DBA_SEGMENTS`视图: ```sql SELECT segment_name, hwm_block_number FROM dba_segments WHERE owner = 'YOUR_USER' AND segment_name = 'YOUR_TABLE_SEGMENT'; ``` 同样替换`YOUR_USER`和`YOUR_TABLE_SEGMENT`。 3. **查看空间的所有HWM**: 如果你需要查看所有段的HWM,可以结合`USER_SEGMENTS`视图和`ALL_TAB_SEGMENTS`视图: ```sql SELECT seg.segment_name, seg.hwm_block_number FROM user_segments seg, all_tab_segments atts WHERE seg.table_name = atts.table_name AND seg.table_owner = atts.owner AND seg.tablespace_name = atts.tablespace_name; ``` 请注意,查询结果中的`hwm_block_number`是一个相对位置,它基于数据库的下一个分配单元,不是绝对的物理地址。对于实时监控,议配合使用闪回区 (`FLASHBACK DATABASE`) 或者使用Oracle Database Performance Analyzer (Dbtune Advisor)。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值