在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

Oracle数据库的表有多大

131次阅读
没有评论

共计 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字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 国产成人一区二区三区影院免费 | 狠狠色噜噜狠狠狠888米奇视频 | 成人午夜精品久久不卡 | 337p粉嫩日本欧洲亚洲大胆 | 色欲人妻综合aaaaaaaa网 | 国产成人精品免费视频大全 | 精品av熟女一区二区偷窥海滩 | 人妻久久久一区二区三区 | 宗合久久 | 国产白虎 | 国产高清福利91成人 | 91夜夜人人揉人人捏人人添 | 精品国产高清在线看国产 | 欧美日韩大片在线观看 | 亚州久久 | 久久久久久网址 | 九九热视频精品在线观看 | 欧美xxxx色视频在线观看 | 久久久婷 | 无码人妻精品一区二区三区66 | 两个人看www免费视频 | 99国产精品免费视频 | 欧美 日韩 国产 在线 | 免费的拍拍视频在线观看 | 成人久久精品一区二区三区 | 欧美亚洲网 | 亚洲人ⅴsaⅴ国产精品 | 男人用嘴添女人下身免费视频 | 男女男精品视频 | 免费a级毛片永久免费 | 极品熟妇大蝴蝶20p 极品丝袜高跟91白沙发在线 | 亚洲一区视频 | 国产成人91 | 亚洲精品一区二区观看 | 久久激情视频 | 深夜看片在线观看18 | 久久99精品久久久久久园产越南 | 亚洲网站免费 | 久久er99热这里只是精品 | 国产露脸精品产三级国产av | 国产对白国语对白 |