亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Oracle數據庫的表有多大

發布時間:2021-09-15 17:24:39 來源:億速云 閱讀:167 作者:chen 欄目:數據庫

這篇文章主要講解了“Oracle數據庫的表有多大”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Oracle數據庫的表有多大”吧!

1. 查看一般表的大小

select segment_name,segment_type,bytes/1024/1024 M from dba_segments where  segment_name='SETTINGS$' and segment_type='TABLE';

2. 查看帶有LOB字段的表的大小

LOB字段是有額外的專門區域存放,查看帶有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;

詳細介紹內容可以查看Doc ID 118531.1

如果想查看這個庫里有多少個帶有LOB字段的表呢?通過dba_lobs可以查看。

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

如果搜出幾百個幾千個LOB字段的表,一個個查大小,會很久…………

怎么把帶有LOB字段的表一次性列出來呢?

先創建一個臨時表:

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數據庫的表有多大”的內容了,經過本文的學習后,相信大家對Oracle數據庫的表有多大這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

罗甸县| 土默特左旗| 云安县| 清涧县| 康平县| 镇巴县| 广德县| 墨江| 耿马| 南安市| 青川县| 灵璧县| 黑龙江省| 仲巴县| 渑池县| 宜良县| 乡城县| 聂荣县| 民乐县| 昌平区| 大埔区| 习水县| 陕西省| 静乐县| 高淳县| 苍南县| 蕲春县| 鹿泉市| 松原市| 满城县| 林西县| 务川| 无棣县| 夏河县| 琼结县| 连江县| 惠水县| 福贡县| 云霄县| 皮山县| 灌云县|