辽宁省住房和建设厅:dba_tables 和 dba_segments

来源:百度文库 编辑:九乡新闻网 时间:2024/05/12 00:22:47
 表中 blocks 的区别 收藏
创建测试表:SQL> create table t5(id int);
表已创建。
SQL> insert into t5 values(1);
已创建 1 行。
SQL> insert into t5 values(2);
已创建 1 行。
SQL> insert into t5 values(3);
已创建 1 行。
SQL> insert into t5 values(4);
已创建 1 行。
SQL> commit;
提交完成。多插入一点数据:
SQL> begin
  2 for i in 1 .. 1000 loop
  3 insert into T5 values(10000);
  4 commit;
  5 end loop;
  6 end;
  7 /
分析表SQL> analyze table T5 compute statistics;表已分析。  查看dba_segments 和 DBA_TABLES表中 blocks 值:SQL> select segment_name,blocks,extents,bytes,segment_type,tablespace_name fromdba_segments where segment_name='T5';
SEGME     BLOCKS    EXTENTS      BYTES SEGMENT_TYPE       TABLESPACE_NAME----- ---------- ---------- ---------- ------------------ ----------------------T5          6528         66   53477376 TABLE              SYSTEM
SQL> select blocks,empty_blocks from dba_tables where table_name = 'T5';BLOCKS EMPTY_BLOCKS----------   ------------6449           78  从上面的结果看以看出:6528 = 6449+78 +1即:Dba_Segments .blocks = Dba_Tables.Blocks+Dba_Tables.Empty_Blocks +1(segment header block)这个多加的1是,是segment header block.  如果查询的结果不是这样,可能是你没有分析表。 不妨分析表之后在查一下看看。  本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/tianlesoftware/archive/2010/06/27/5697331.aspx