Oracle估算表大小的小方法

来源:互联网 发布:sql默认值 编辑:程序博客网 时间:2024/04/26 22:41

 查看了一下ALL_TABLES 表,其中有个字段:avg_row_len. 该值单位为bytes。 可以一句这个字段来进行一个估算。 

AVG_ROW_LEN* NUMBER 
Average length of a row in the table (in bytes) 
http://download.oracle.com/docs/cd/E11882_01/server.112/e17110/statviews_2117.htm#i1592091 
根据对表大小的估算,进而可以估算出整个数据库的大小。 在项目测试阶段,可以根据所有对象进行估算,从而可以估算出系统上线以后数据库的大小,根据这些数据可以规划存储。这里要注意一点,要给备份留足存储空间。 一般备份需要的空间是DB的2-3倍。 如果DB 是100G,那么给备份的空间最好是200G以上。 

根据dba_segments视图可以查看数据库中占用存储空间的对象: 
SYS@anqing2(rac2)> select distinctsegment_type from dba_segments; 

SEGMENT_TYPE 
------------------ 
LOBINDEX 
INDEX PARTITION 
TABLE PARTITION 
NESTED TABLE 
ROLLBACK 
LOB PARTITION 
LOBSEGMENT 
INDEX 
TABLE 
CLUSTER 
TYPE2 UNDO 

11 rows selected. 

这里主要就是表和索引。把所有表和索引的大小估算出来,在相加就可以估算出DB的大小了。 


二. 估算表的大小 
表的大小=记录数*平均字段大小(avg_row_len) 

Avg_row_len 可以通过如下SQL 查询。 其单位为bytes。 
SYS@anqing2(rac2)> selecttable_name,avg_row_len from all_tables where table_name='T1'; 

TABLE_NAME AVG_ROW_LEN 
------------------------------ ----------- 
T1 93 

如果T1 表未来估计为1000万行,那么其大小就是1000w*93bytes。 


三.估算表上索引的大小 
All_indexes 视图没有all_tables 上的avg_row_len 字段,不过我们可以通过视图和表大小的一个比率进行估算。 表的大小我们可以估算出来,索引的大小可以通过这个比率进行估算。 

SQL>create index idx_t1_created on t1(created) 
SQL>exec dbms_stats.gather_table_stats('SYS','T1',cascade=>TRUE) 

SYS@anqing2(rac2)> selectsegment_name,segment_type,bytes,blocks from dba_segments where segment_namein ('T1','IDX_T1_CREATED'); 

SEGMENT_NAME SEGMENT_TYPE BYTES BLOCKS 
--------------- ---------------------------- ---------- 
T1 TABLE 6291456 768 
IDX_T1_CREATED INDEX 2097152 256 

计算索引和表的比率: 
SYS@anqing2(rac2)> select (2097152/6291456)*100,(256/768)*100 from dual; 

(2097152/6291456)*100 (256/768)*100 
--------------------- ------------- 
33.3333333 33.3333333 

从bytes 和 blocks 的比率是一样,即索引是表的33%。 那么如果估算表以后的大小是1000M,那么对应的索引大小就是1000M*33%=330M。 

把所有表和索引的大小加起来,就是整个数据库大小的估算值。


1.创建测试表和索引

SQL> create table t as select * from dba_objects;

Table created.

 

SQL> create index t_ind on t(object_id);

Index created.

 

2.收集统计信息

SQL> exec dbms_stats.gather_table_stats(user,'t',cascade=>true);             

PL/SQL procedure successfully completed.

 

3.计算

SQL> select avg_row_len from user_tables where table_name='T';

AVG_ROW_LEN
-----------
  98

 

SQL> select segment_name,segment_type,bytes from user_segments where segment_name in('T','T_IND');

SEGMENT_NAME           SEGMENT_TYPE    BYTES
--------------------------------------------------------------------------------- ------------------ ----------
T            TABLE   9437184
T_IND            INDEX   2097152

 

SQL> select trunc((2097152/9437184)*100) ind_pct from dual;

   IND_PCT
----------
 22

 

表大小=row_number*98 *(1+0.22) bytes



整理自《让Oracle跑的更快》谭怀远

转:http://blog.csdn.net/jxzkin/article/details/7659323

0 0
原创粉丝点击