這篇文章主要講解了“Oracle數(shù)據(jù)庫的表有多大”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Oracle數(shù)據(jù)庫的表有多大”吧!
彰武網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁設計、網(wǎng)站建設、微信開發(fā)、APP開發(fā)、自適應網(wǎng)站建設等網(wǎng)站項目制作,到程序開發(fā),運營維護。創(chuàng)新互聯(lián)于2013年創(chuàng)立到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設就選創(chuàng)新互聯(liá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字段的表的大小比較復雜,分為了普通的字段大小,LOB字段大小,LOB索引字段大小,三個部分。
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;
詳細介紹內(nèi)容可以查看Doc ID 118531.1
如果想查看這個庫里有多少個帶有LOB字段的表呢?通過dba_lobs可以查看。
例如:select distinct owner,table_name from dba_lobs where owner in ('***',’***’);
如果搜出幾百個幾千個LOB字段的表,一個個查大小,會很久…………
怎么把帶有LOB字段的表一次性列出來呢?
先創(chuàng)建一個臨時表:
SQL> create table candidates (owner varchar2(30),segment_name varchar2(81));
再把上面查出來的帶有LOB字段的表插入進臨時表里:
SQL> insert into candidates values ('owner','table_name');
然后利用游標:
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; /
就會把帶有LOB字段的表大小都列出來了。
一般查大小就只查dba_segments了,查LOB的時候好像不多。偶爾查一下就用步驟2的方法就行,也是官方提供的。
感謝各位的閱讀,以上就是“Oracle數(shù)據(jù)庫的表有多大”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對Oracle數(shù)據(jù)庫的表有多大這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關知識點的文章,歡迎關注!