Oracle數(shù)據(jù)庫(kù)的表有多大呢?
一般來說,查表占據(jù)了多少的物理空間用的是dba_segments這個(gè)數(shù)據(jù)字典,這個(gè)數(shù)據(jù)字典展示了segment_type(段類型,如table,index,function,procedure 等等的段類型),bytes(段大小),blocks(段占用了多少個(gè)數(shù)據(jù)塊)extents(分配了多少個(gè)區(qū))等吧,信息很詳細(xì),可以直接select * from dba_segments;查看,用具有查看數(shù)據(jù)字典權(quán)限的用戶查看。(給用戶授予了SELECT_CATALOG_ROLE角色,普通用戶就具有了查詢數(shù)據(jù)字典的權(quán)限。)一般不要給普通用戶dba角色,保持權(quán)限最小化原則。
1. 查看一般表的大小
select segment_name,segment_type,bytes/1024/1024 M from dba_segments where segment_name='SETTINGS$' and segment_type='TABLE';
2. 查看帶有LOB字段的表的大小
LOB字段是有額外的專門區(qū)域存放,查看帶有LOB字段的表的大小比較復(fù)雜,分為了普通的字段大小,LOB字段大小,LOB索引字段大小,三個(gè)部分。
- SELECT (SELECT SUM(S.BYTES/1024/1024/1024)
- -- The Table Segment size
- FROM DBA_SEGMENTS S WHERE S.OWNER = UPPER('表的owner') AND (S.SEGMENT_NAME = UPPER('表名'))) + (SELECT
- SUM(S.BYTES/1024/1024/1024)
- -- The Lob Segment Size
- FROM DBA_SEGMENTS S, DBA_LOBS L WHERE S.OWNER = UPPER('表的owner') AND (L.SEGMENT_NAME = S.SEGMENT_NAME AND L.TABLE_NAME = UPPER('表名') AND L.OWNER =
- UPPER('表的owner'))) + (SELECT SUM(S.BYTES/1024/1024/1024)
- -- The Lob Index size
- FROM DBA_SEGMENTS S, DBA_INDEXES I WHERE S.OWNER = UPPER('表的owner') AND
- (I. INDEX_NAME = S.SEGMENT_NAME AND I.TABLE_NAME = UPPER('表名') AND INDEX_TYPE= 'LOB' AND I.OWNER = UPPER('表的owner'))) "TOTAL TABLE SIZE" FROM DUAL;
詳細(xì)介紹內(nèi)容可以查看Doc ID 118531.1
如果想查看這個(gè)庫(kù)里有多少個(gè)帶有LOB字段的表呢?通過dba_lobs可以查看。
例如:select distinct owner,table_name from dba_lobs where owner in ('***',’***’);
如果搜出幾百個(gè)幾千個(gè)LOB字段的表,一個(gè)個(gè)查大小,會(huì)很久…………
怎么把帶有LOB字段的表一次性列出來呢?
先創(chuàng)建一個(gè)臨時(shí)表:
- SQL> create table candidates (owner varchar2(30),segment_name varchar2(81));
再把上面查出來的帶有LOB字段的表插入進(jìn)臨時(shí)表里:
- SQL> insert into candidates values ('owner','table_name');
然后利用游標(biāo):
- SQL> set serveroutput on
- SQL> declare
- cursor cur_temp is select owner, segment_name from candidates;
- v_owner varchar2(30);
- v_segment_name varchar2(81);
- v_total_table_size number;
- begin
- open cur_temp;
- fetch cur_temp into v_owner,v_segment_name;
- while cur_temp%FOUND
- loop
- SELECT
- (
- SELECT
- nvl(SUM(S.BYTES/1024/1024/1024),0)
- FROM
- DBA_SEGMENTS S
- WHERE
- S.OWNER = UPPER(v_owner) AND
- (S.SEGMENT_NAME = UPPER(v_segment_name)))
- +
- (SELECT
- nvl(SUM(S.BYTES/1024/1024/1024),0)
- FROM
- DBA_SEGMENTS S,
- DBA_LOBS L
- WHERE
- S.OWNER = UPPER(v_owner) AND
- (L.SEGMENT_NAME = S.SEGMENT_NAME AND L.TABLE_NAME = UPPER(v_segment_name) AND
- L.OWNER = UPPER(v_owner))
- )
- +
- (SELECT
- nvl(SUM(S.BYTES/1024/1024/1024),0)
- FROM
- DBA_SEGMENTS S,
- DBA_INDEXES I
- WHERE
- S.OWNER = UPPER(v_owner) AND
- (I.INDEX_NAME = S.SEGMENT_NAME AND I.TABLE_NAME = UPPER(v_segment_name) AND INDEX_TYPE= 'LOB' AND I.OWNER = UPPER(v_owner))
- ) "TOTAL TABLE SIZE" into v_total_table_size
- FROM
- DUAL;
- DBMS_OUTPUT.PUT_LINE('Table '||v_segment_name||': '||v_total_table_size);
- fetch cur_temp into v_owner,v_segment_name;
- end loop;
- end;
- /
就會(huì)把帶有LOB字段的表大小都列出來了。
一般查大小就只查dba_segments了,查L(zhǎng)OB的時(shí)候好像不多。偶爾查一下就用步驟2的方法就行,也是官方提供的。