SELECT SEGMENT_NAME, BYTES FROM USER_SEGMENTS where SEGMENT_TYPE='TABLE'
===== 실제 사용공간 측정 =====
- Table에 공간할당은 되었으나 아직 (전혀) 사용되지 않는 공간을 제외한 실제 사용되고 있는 공간을 계산하는 방법이다.
- 즉, High Water Mark(HWM) 아래의 공간을 측정하는 것이다.
==== 측정방법 ====
- 해당 Table을 Analyze 한다. analyze table compute statistics;
- 해당 Table의 blocks를 구한다. select blocks from dba_tables where table_name ='';
**blocks + 1(segment header block)** : 해당 Table 이 사용중인 database block count , HWM
- 위의 계산에는 사용된 후 delete에 의해 현재 완전히 비어 있는 block도 사용하고 있는 block으로 인식하므로 \\ 완전히 비어 있는 block을 제거하기 위해서는 아래의 결과값이 나온 block만 계산하면 된다.
- rowid는 다음과 같이 구성되어 있다.
object fil block row
------ --- ------ ---
AAABPW AAF AAAAv1 AAA
- 따라서 아래의 Query를 실행하면 결과를 얻을 수 있다. \\ HWM 아래 할당은 되었지만 완전히 비어 있는 block은 계산에서 제외되고, 조금이라도 사용된 block count만 계산된다.
SELECT COUNT(1)
FROM (SELECT SUBSTR(ROWID,1,15) FROM GROUP BY SUBSTR(ROWID,1,15) );
===== 예제 =====
- costs 라는 테이블의 실제 용량을 확인해 보자.
==== 스크립트 ====
- 통계분석
SQL> analyze table costs compute statistics;
Table analyzed.
- block count를 알아낸다.
SQL> select blocks from user_tables where table_name='COSTS';
BLOCKS
----------
2924
2924는 HWM 아래 block count 이다.
- HWM 아래에 완전히 비어있는 block count를 알아낸다.
SQL> select count(1)from (select substr(rowid,1,15) from costs group by substr(rowid,1,15));
COUNT(1)
----------
2506
2506은 HWM 아래 block 중 사용중인 block count 이다.
===== 정리 =====
- Table의 공간(크기)이란 아래 3가지 관점에서 값이 각각 다를수 있습니다.
=== ===
^ 해당 Table에 할당된 크기 | Table에 할당되었지만 사용중 또는 미사용공간 전부 포함 |
^ HWM 아래 크기 | 할당된 공간중에서 full table scan시 검색하는 부분까지만의 크기 \\ 즉 HWM이후 공간은 아직 한번도 사용이 안된 new block이다 |
^ HWM 아래중 완전히 비어 있는 \\ block을 제외한 크기 | delete에 의해 block전체가 비어 있는 block을 제외한 크기 |
===== 생각해보자 =====
- USER_SEGMENTS 의 BYTES는 실데이타 공간이 아니라 할당영역을 나타낸 것이다. \\ 빈 블럭도 포함이 된다
- 만일 UNUSED 블럭을 제외한 실제 데이타 공간을 구하려면 아래와 같이 구하면 된다. \\ 쿼리상의 8192는 show parameter의 DB_BLOCK_SIZE의 값이다. \\ 이 구문 역시 정확한 값을 얻기 위해서는 **ANALYZE TABLE** 을 해 주어야 한다.
SELECT TABLE_NAME,
GREATEST(4, CEIL(NUM_ROWS /
((ROUND(((8192 - (INI_TRANS * 23)) *
((100 - PCT_USED) /100)) / AVG_ROW_LEN)))) *
8192)/1024/1024 TABLESIZE_MBYTES
FROM USER_TABLES ;