辽宁省住房和建设厅: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
创建测试表: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