久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

Oracle數據庫的表有多大

148次閱讀
沒有評論

共計 2591 個字符,預計需要花費 7 分鐘才能閱讀完成。

這篇文章主要講解了“Oracle 數據庫的表有多大”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著丸趣 TV 小編的思路慢慢深入,一起來研究和學習“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  (***,rsquo;*** rsquo;);

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

怎么把帶有 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 數據庫的表有多大這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是丸趣 TV,丸趣 TV 小編將為大家推送更多相關知識點的文章,歡迎關注!

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-07-28發表,共計2591字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 德州市| 遵义县| 磐石市| 雷山县| 遂平县| 凌云县| 佛教| 东港市| 玉溪市| 合水县| 敦化市| 中方县| 三亚市| 尼木县| 比如县| 正安县| 宾阳县| 泌阳县| 阿克| 华宁县| 于都县| 桃园市| 泰宁县| 双辽市| 合山市| 新疆| 当阳市| 石门县| 达尔| 南澳县| 客服| 霍邱县| 墨脱县| 涟水县| 安丘市| 平武县| 措美县| 丰原市| 宝鸡市| 闸北区| 屯留县|