Oracle表段中的高水位線HWM

2021-04-19 08:10:34 字數 1969 閱讀 7765

在oracle資料的儲存中,可以把儲存空間想象為乙個水庫,資料想象為水庫中的水。水庫中的水的位置有一條線 叫做水位線,在oracle中,這條線被稱為高水位線(high-warter mark, hwm)。在資料庫錶剛建立的時候,由於沒有任何資料,所以這個時候水位線是空的,也就是說hwm為最低值。當插入了資料以後,高水位線就會**,但是這 裡也有乙個特性,就是如果你採用delete語句刪除資料的話,資料雖然被刪除了,但是高水位線卻沒有降低,還是你剛才刪除資料以前那麼高的水位。也就是 說,這條高水位線在日常的增刪操作中只會**,不會**。

下面我們來談一下oracle中select語句的特性。select語句會對錶中的資料進行一次掃瞄,但是究 竟掃瞄多少資料儲存塊呢,這個並不是說資料庫中有多少資料,oracle就掃瞄這麼大的資料塊,而是oracle會掃瞄高水位線以下的資料塊。現在來想象 一下,如果剛才是一張剛剛建立的空表,你進行了一次select操作,那麼由於高水位線hwm在最低的0位置上,所以沒有資料塊需要被掃瞄,掃瞄時間會極 短。而如果這個時候你首先插入了一千萬條資料,然後再用delete語句刪除這一千萬條資料。由於插入了一千萬條資料,所以這個時候的高水位線就在一千萬 條資料這裡。後來刪除這一千萬條資料的時候,由於delete語句不影響高水位線,所以高水位線依然在一千萬條資料這裡。這個時候再一次用select語 句進行掃瞄,雖然這個時候表中沒有資料,但是由於掃瞄是按照高水位線來的,所以需要把一千萬條資料的儲存空間都要掃瞄一次,也就是說這次掃瞄所需要的時間 和掃瞄一千萬條資料所需要的時間是一樣多的。所以有時候有人總是經常說,怎麼我的表中沒有幾條資料,但是還是這麼慢呢,這個時候其實奧秘就是這裡的高水位 線了。

那有沒有辦法讓高水位線下降呢,其實有一種比較簡單的方法,那就是採用truncate語句進行刪除資料。採用truncate語句刪除乙個表的資料的時 候,類似於重新建立了表,不僅把資料都刪除了,還把hwm給清空恢復為0。所以如果需要把錶清空,在有可能利用truncate語句來刪除資料的時候就利 用truncate語句來刪除表,特別是那種資料量有可能很大的臨時儲存表。

在手動段空間管理(manual segment space management)中,段中只有乙個hwm,但是在oracle9irelease1才新增的自動段空間管理(automatic segment space management)中,又有了乙個低hwm的概念出來。為什麼有了hwm還又有乙個低hwm呢,這個是因為自動段空間管理的特性造成的。在手段段空間 管理中,當資料插入以後,如果是插入到新的資料塊中,資料塊就會被自動格式化等待資料訪問。而在自動段空間管理中,資料插入到新的資料塊以後,資料塊並沒 有被格式化,而是在第一次在第一次訪問這個資料塊的時候才格式化這個塊。所以我們又需要一條水位線,用來標示已經被格式化的塊。這條水位線就叫做低 hwm。一般來說,低hwm肯定是低於等於hwm的。

修正oracle表的高水位線

在oracle中,執行對錶的刪除操作不會降低該錶的高水位線。而全表掃瞄將始終讀取乙個段(extent)中所有低於高水位線標記的塊。如果在執行刪除操作後不降低高水位線標記,則將導致查詢語句的效能低下。下面的方法都可以降低高水位線標記。

1.執行表重建指令 alter table

table_name move; (

不跟參數列還是在原來的表空間,move後記住重建索引

如果以後還要繼續向這個表增加資料,沒有必要move,

只是釋放出來的空間,只能這個錶用,其他的表或者segment無法使用該空間

)2.執行alter table

table_name shrink space; 注意,此命令為oracle 10g新增功能,再執行該指令之前必須允許行移動 alter table

table_name enable row movement;

3.複製要保留的資料到臨時表t,drop原表,然後rename臨時表t為原表

4.emp/imp

5.alter   table  table_name  deallocate   unused  

6.盡量truncate 吧

Oracle表段中的高水位線HWM

在 oracle 資料的儲存中,可以把儲存空間想象為乙個水庫,資料想象為水庫中的水。水庫中的水的位置有一條線叫做水位線,在 oracle 中,這條線被稱為高水位線 high warter mark,hwm 在資料庫錶剛建立的時候,由於沒有任何資料,所以這個時候水位線是空的,也就是說 hwm為最低值。...

Oracle表段中的高水位線HWM

在oracle資料的儲存中,可以把儲存空間想象為乙個水庫,資料想象為水庫中的水。水庫中的水的位置有一條線叫做水位線,在oracle中,這條線被稱為高水位線 high warter mark,hwm 在資料庫錶剛建立的時候,由於沒有任何資料,所以這個時候水位線是空的,也就是說hwm為最低值。當插入了資...

Oracle表段中的高水位線HWM收藏

在oracle資料的儲存中,可以把儲存空間想象為乙個水庫,資料想象為水庫中的水。水庫中的水的位置有一條線叫做水位線,在oracle中,這條線被稱為高水位線 high warter mark,hwm 在資料庫錶剛建立的時候,由於沒有任何資料,所以這個時候水位線是空的,也就是說hwm為最低值。當插入了資...