Oracle数据库的表有多大呢?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle数据库的表有多大呢?相关的知识,希望对你有一定的参考价值。

一般来说,查表占据了多少的物理空间用的是dba_segments这个数据字典,这个数据字典展示了segment_type(段类型,如table,index,function,procedure 等等的段类型),bytes(段大小),blocks(段占用了多少个数据块)extents(分配了多少个区)等吧,信息很详细,可以直接select from dba_segments;查看,用具有查看数据字典权限的用户查看。
作者:女DBA的后花园来源:今日头条|2020-08-03 11:52
收藏
分享
一般来说,查表占据了多少的物理空间用的是dba_segments这个数据字典,这个数据字典展示了segment_type(段类型,如table,index,function,procedure 等等的段类型),bytes(段大小),blocks(段占用了多少个数据块)extents(分配了多少个区)等吧,信息很详细,可以直接select
from dba_segments;查看,用具有查看数据字典权限的用户查看。(给用户授予了SELECT_CATALOG_ROLE角色,普通用户就具有了查询数据字典的权限。)一般不要给普通用户dba角色,保持权限最小化原则。
技术图片

  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索引字段大小,三个部分。
1.  SELECT (SELECT SUM(S.BYTES/1024/1024/1024)  
2.  -- The Table Segment size  
3.  FROM DBA_SEGMENTS S WHERE S.OWNER = UPPER(‘表的owner‘) AND (S.SEGMENT_NAME = UPPER(‘表名‘))) + (SELECT  
4.  SUM(S.BYTES/1024/1024/1024)  
5.  -- The Lob Segment Size  
6.  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 = 
7.   
8.  UPPER(‘表的owner‘))) + (SELECT SUM(S.BYTES/1024/1024/1024)  
9.  -- The Lob Index size  
10. FROM DBA_SEGMENTS S, DBA_INDEXES I WHERE S.OWNER = UPPER(‘表的owner‘) AND  
11. (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字段的表一次性列出来呢?
先创建一个临时表:

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

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

1.  SQL> insert into candidates values (‘owner‘,‘table_name‘); 
然后利用游标:
1.  SQL> set serveroutput on  
2.  SQL> declare  
3.  cursor cur_temp is select owner, segment_name from candidates;  
4.  v_owner varchar2(30);  
5.  v_segment_name varchar2(81);  
6.  v_total_table_size number;  
7.  begin  
8.  open cur_temp;  
9.  fetch cur_temp into v_owner,v_segment_name;  
10. while cur_temp%FOUND  
11. loop  
12. SELECT  
13. (  
14. SELECT  
15. nvl(SUM(S.BYTES/1024/1024/1024),0)  
16. FROM  
17. DBA_SEGMENTS S  
18. WHERE  
19. S.OWNER = UPPER(v_owner) AND  
20. (S.SEGMENT_NAME = UPPER(v_segment_name)))  
21. +  
22. (SELECT  
23. nvl(SUM(S.BYTES/1024/1024/1024),0)  
24. FROM  
25. DBA_SEGMENTS S,  
26. DBA_LOBS L  
27. WHERE  
28. S.OWNER = UPPER(v_owner) AND  
29. (L.SEGMENT_NAME = S.SEGMENT_NAME AND L.TABLE_NAME = UPPER(v_segment_name) AND  
30. L.OWNER = UPPER(v_owner))  
31. )  
32. +  
33. (SELECT  
34. nvl(SUM(S.BYTES/1024/1024/1024),0)  
35. FROM  
36. DBA_SEGMENTS S,  
37. DBA_INDEXES I  
38. WHERE  
39. S.OWNER = UPPER(v_owner) AND  
40. (I.INDEX_NAME = S.SEGMENT_NAME AND I.TABLE_NAME = UPPER(v_segment_name) AND INDEX_TYPE= ‘LOB‘ AND I.OWNER = UPPER(v_owner))  
41. ) "TOTAL TABLE SIZE" into v_total_table_size  
42. FROM  
43. DUAL;  
44. DBMS_OUTPUT.PUT_LINE(‘Table ‘||v_segment_name||‘: ‘||v_total_table_size);  
45. fetch cur_temp into v_owner,v_segment_name;  
46. end loop;  
47. end;  
48. / 

就会把带有LOB字段的表大小都列出来了。
一般查大小就只查dba_segments了,查LOB的时候好像不多。偶尔查一下就用步骤2的方法就行,也是官方提供的。
【编辑推荐】

  1. 详解Oracle数据库LRU算法--LRU链、脏块与脏LRU链
  2. 80% 的 Oracle JDK 用户正在考虑其他支持选项
  3. Oracle SQL性能优化40条 | 收藏了!
  4. 史上最全Oracle文件损坏处理办法 (附实验步骤)
  5. 干货满满!史上超全 Oracle ADG 部署架构、变化及应急处置思路
    【责任编辑:未丽燕 TEL:(010)68476606】

以上是关于Oracle数据库的表有多大呢?的主要内容,如果未能解决你的问题,请参考以下文章

这款万用表的内阻有多大呢?

魅族搭配的三星Exynos 4210和4412性能差距有多大呢

如何在ORACLE中查询某一用户下所有的空表

C语言中malloc和静态数组最多能开到多大呢

mysql 数据库可以有多大

挖矿丨你有多大的几率获得一个Chia区块?