Oracle數(shù)據(jù)庫(kù)的表有多大

這篇文章主要講解了“Oracle數(shù)據(jù)庫(kù)的表有多大”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“Oracle數(shù)據(jù)庫(kù)的表有多大”吧!

彰武網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、APP開(kāi)發(fā)、自適應(yīng)網(wǎng)站建設(shè)等網(wǎng)站項(xiàng)目制作,到程序開(kāi)發(fā),運(yùn)營(yíng)維護(hù)。創(chuàng)新互聯(lián)于2013年創(chuàng)立到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來(lái)保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(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字段是有額外的專門(mén)區(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字段的表呢?通過(guò)dba_lobs可以查看。

例如:select distinct owner,table_name from dba_lobs where owner in  ('***',’***’);

如果搜出幾百個(gè)幾千個(gè)LOB字段的表,一個(gè)個(gè)查大小,會(huì)很久…………

怎么把帶有LOB字段的表一次性列出來(lái)呢?

先創(chuàng)建一個(gè)臨時(shí)表:

SQL> create table candidates (owner varchar2(30),segment_name varchar2(81));

再把上面查出來(lái)的帶有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字段的表大小都列出來(lái)了。

一般查大小就只查dba_segments了,查L(zhǎng)OB的時(shí)候好像不多。偶爾查一下就用步驟2的方法就行,也是官方提供的。

感謝各位的閱讀,以上就是“Oracle數(shù)據(jù)庫(kù)的表有多大”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)Oracle數(shù)據(jù)庫(kù)的表有多大這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

新聞標(biāo)題:Oracle數(shù)據(jù)庫(kù)的表有多大
本文鏈接:http://bm7419.com/article32/pciopc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站、云服務(wù)器、關(guān)鍵詞優(yōu)化服務(wù)器托管、網(wǎng)站收錄、Google

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁(yè)設(shè)計(jì)