水位線

水位線

水位線(High Water Mark)在工程地質、岩土工程、水利水電工程等專業的地質剖面圖等專業圖件中表示地表水或地下水水位的線,稱作水位線。線型為虛線,符號為▽下面加三條長度依次減小的線段。

高水位線

所有的oracle段(segments,在此,為了理解方便,建議把segment作為表的一個同義詞) 都有一個在段內容納數據的上限,我們把這個上限稱為"high water mark"或HWM。這個HWM是一個標記,用來說明已經有多少沒有使用的數據塊分配給這個segment。HWM通常增長的幅度為一次5個數據塊,原則上HWM只會增大,不會縮小,即使將表中的數據全部刪除,HWM還是為原值,由於這個特點,使HWM很象一個水庫的歷史最高水位,這也就是HWM的原始含義,當然不能說一個水庫沒水了,就說該水庫的歷史最高水位為0。但是如果我們在表上使用了truncate命令,則該表的HWM會被重新置為0。
HWM資料庫的操作有如下影響:
a) 全表掃描通常要讀出直到HWM標記的所有的屬於該表資料庫塊,即使該表中沒有任何數據。
b) 即使HWM以下有空閒的資料庫塊,鍵入在插入數據時使用了append關鍵字,則在插入時使用HWM以上的數據塊,此時HWM會自動增大。
如何知道一個表的HWM?
a) 首先對表進行分析:
ANALYZE TABLE <tablename> ESTIMATE/COMPUTE statistics;
b) SELECT blocks, empty_blocks, num_rows
FROM user_tables
WHERE table_name = <tablename>;
BLOCKS 列代表該表中曾經使用過得資料庫塊的數目,即水線。
EMPTY_BLOCKS 代表分配給該表,但是在水線以上的資料庫塊,即從來沒有使用的數據塊。
讓我們以一個有28672行的BIG_EMP1表為例進行說明:
1) SQL> SELECT segment_name,segment_type,blocks FROM dba_segments WHERE segment_name=&#39;BIG_EMP1&#39;;
SEGMENT_NAME SEGMENT_TYPE BLOCKS EXTENTS
----------------------------- ----------------- ---------- -------
BIG_EMP1 TABLE 1024 2
1 row selected.
2) SQL> ANALYZE TABLE big_emp1 ESTIMATE STATISTICS;
Statement processed.
3) SQL> SELECT table_name,num_rows,blocks,empty_blocks FROM user_tables WHERE table_name=&#39;BIG_EMP1&#39;;
TABLE_NAME NUM_ROWS BLOCKS EMPTY_BLOCKS
------------------------------ ---------- ---------- ------------
BIG_EMP1 28672 700 323
1 row selected.
注意:
BLOCKS + EMPTY_BLOCKS (700+323=1023)比DBA_SEGMENTS.BLOCKS少個資料庫塊,這是因為有一個資料庫塊被保留用作segment header。DBA_SEGMENTS.BLOCKS 表示分配給這個表的所有的資料庫塊的數目。USER_TABLES.BLOCKS表示已經使用過的資料庫塊的數目。
4) SQL> SELECT COUNT (DISTINCT
DBMS_ROWID.ROWID_BLOCK_NUMBER(rowid)||
DBMS_ROWID.ROWID_RELATIVE_FNO(rowid)) "Used"
FROM big_emp1;
Used
----------
700
1 row selected.
5) SQL> DELETE from big_emp1;
28672 rows processed.
6) SQL> commit;
Statement processed.
7) SQL> ANALYZE TABLE big_emp1 ESTIMATE STATISTICS;
Statement processed.
8) SQL> SELECT table_name,num_rows,blocks,empty_blocks FROM user_tables WHERE table_name=&#39;BIG_EMP1&#39;;
TABLE_NAME NUM_ROWS BLOCKS EMPTY_BLOCKS
------------------------------ ---------- ---------- ------------
BIG_EMP1 0 700 323
1 row selected.
9) SQL> SELECT COUNT (DISTINCT
DBMS_ROWID.ROWID_BLOCK_NUMBER(rowid)||
DBMS_ROWID.ROWID_RELATIVE_FNO(rowid)) "Used"
FROM big_emp1;
Used
----------
0 -- 這表名沒有任何資料庫塊容納數據,即表中無數據
1 row selected.
10) SQL> Truncate Table big_emp1;
Statement processed.
11) SQL> ANALYZE TABLE big_emp1 ESTIMATE STATISTICS;
Statement processed.
12) SQL> SELECT table_name,num_rows,blocks,empty_blocks FROM user_tables WHERE table_name=&#39;BIG_EMP1&#39;;
TABLE_NAME NUM_ROWS BLOCKS EMPTY_BLOCKS
------------------------------ ---------- ---------- ------------
BIG_EMP1 0 0 511
1 row selected.
13) SQL> SELECT segment_name,segment_type,blocks FROM dba_segments WHERE segment_name=&#39;BIG_EMP1&#39;;
SEGMENT_NAME SEGMENT_TYPE BLOCKS EXTENTS
----------------------------- ----------------- ---------- -------
BIG_EMP1 TABLE 512 1
1 row selected.
注意:
TRUNCATE命令回收了由delete命令產生的空閒空間,注意該表分配的空間由原先的1024塊降為512塊。
為了保留由delete命令產生的空閒空間,可以使用
TRUNCATE TABLE big_emp1 REUSE STORAGE
用此命令後,該表還會是原先的1024塊。

馬桶水位線

簡介

水位線是在水箱裡面的,水箱是供水和存水的地方,而在水箱內有一條定位線,稱之為“水位線”。水位線是根據不同的用水量、水鍵高低和水箱容量來決定高低的。

馬桶水位線馬桶水位線

水位線作用

水位線只是一個簡單的標識,只須在生產磨具上刻上就可以在產品上出現。水位線一般是沒有或只有一條,但還有的座便器會標有兩條水位線。有部分座便器是有兩條水位線,分別是基本水位線和最高水位線。要求水位最低不能低於下面一條水位線的位置,最高則不能超過最高水位線。因為如果水箱儲存的水量沒有達到一定量的話,可能會產生比較少的虹吸力,影響沖水效果,需要重複沖水,水量太多則會溢出,同樣造成水資源浪費。水位線起到的是一個衡量水位的作用。

相關搜尋

熱門詞條

聯絡我們