这篇文章主要讲解了“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(SELECTSUM(S.BYTES/1024/1024/1024)--TheTableSegmentsizeFROMDBA_SEGMENTSSWHERES.OWNER=UPPER('表的owner')AND(S.SEGMENT_NAME=UPPER('表名')))+(SELECTSUM(S.BYTES/1024/1024/1024)--TheLobSegmentSizeFROMDBA_SEGMENTSS,DBA_LOBSLWHERES.OWNER=UPPER('表的owner')AND(L.SEGMENT_NAME=S.SEGMENT_NAMEANDL.TABLE_NAME=UPPER('表名')ANDL.OWNER=UPPER('表的owner')))+(SELECTSUM(S.BYTES/1024/1024/1024)--TheLobIndexsizeFROMDBA_SEGMENTSS,DBA_INDEXESIWHERES.OWNER=UPPER('表的owner')AND(I.INDEX_NAME=S.SEGMENT_NAMEANDI.TABLE_NAME=UPPER('表名')ANDINDEX_TYPE='LOB'ANDI.OWNER=UPPER('表的owner')))"TOTALTABLESIZE"FROMDUAL;

详细介绍内容可以查看Doc ID 118531.1

如果想查看这个库里有多少个带有LOB字段的表呢?通过dba_lobs可以查看。

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

如果搜出几百个几千个LOB字段的表,一个个查大小,会很久…………

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

先创建一个临时表:

SQL>createtablecandidates(ownervarchar2(30),segment_namevarchar2(81));

再把上面查出来的带有LOB字段的表插入进临时表里:

SQL>insertintocandidatesvalues('owner','table_name');

然后利用游标:

SQL>setserveroutputonSQL>declarecursorcur_tempisselectowner,segment_namefromcandidates;v_ownervarchar2(30);v_segment_namevarchar2(81);v_total_table_sizenumber;beginopencur_temp;fetchcur_tempintov_owner,v_segment_name;whilecur_temp%FOUNDloopSELECT(SELECTnvl(SUM(S.BYTES/1024/1024/1024),0)FROMDBA_SEGMENTSSWHERES.OWNER=UPPER(v_owner)AND(S.SEGMENT_NAME=UPPER(v_segment_name)))+(SELECTnvl(SUM(S.BYTES/1024/1024/1024),0)FROMDBA_SEGMENTSS,DBA_LOBSLWHERES.OWNER=UPPER(v_owner)AND(L.SEGMENT_NAME=S.SEGMENT_NAMEANDL.TABLE_NAME=UPPER(v_segment_name)ANDL.OWNER=UPPER(v_owner)))+(SELECTnvl(SUM(S.BYTES/1024/1024/1024),0)FROMDBA_SEGMENTSS,DBA_INDEXESIWHERES.OWNER=UPPER(v_owner)AND(I.INDEX_NAME=S.SEGMENT_NAMEANDI.TABLE_NAME=UPPER(v_segment_name)ANDINDEX_TYPE='LOB'ANDI.OWNER=UPPER(v_owner)))"TOTALTABLESIZE"intov_total_table_sizeFROMDUAL;DBMS_OUTPUT.PUT_LINE('Table'||v_segment_name||':'||v_total_table_size);fetchcur_tempintov_owner,v_segment_name;endloop;end;/

就会把带有LOB字段的表大小都列出来了。

一般查大小就只查dba_segments了,查LOB的时候好像不多。偶尔查一下就用步骤2的方法就行,也是官方提供的。

感谢各位的阅读,以上就是“Oracle数据库的表有多大”的内容了,经过本文的学习后,相信大家对Oracle数据库的表有多大这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!