dba_tables 和 dba_segments 表中 blocks 的区别
来源:互联网 发布:php允许ajax跨域 编辑:程序博客网 时间:2024/05/22 13:29
创建测试表:
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_tables 中的blocks 是只有收集统计信息以后才有值,而且对于empty_blocks 参数,还必须使用analyze 分析之后才有值。 如果使用dbms_stats.gather_table_stats收集,只能收集到blocks的值,empty_blocks 收集不到。
有关统计信息,参考我的Blog:
Oracle Statistic 统计信息 小结
http://blog.csdn.net/xujinyang/article/details/6881672
查看dba_segments 和 DBA_TABLES表中 blocks 值:
SQL> select segment_name,blocks,extents,bytes,segment_type,tablespace_name from
dba_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.
如果查询的结果不是这样,可能是你没有分析表。 不妨分析表之后在查一下看看。
这两张表对blocks 的定义也不一样:
DBA_SEGMENTS.BLOCKS holds the total number of blocks allocated to the table.
USER_TABLES.BLOCKS holds the total number of blocks allocated for data.
------------------------------------------------------------------------------
- dba_tables 和 dba_segments 表中 blocks 的区别
- dba_tables 和 dba_segments 表中 blocks 的区别
- dba_tables 和 dba_segments 表中 blocks 的区别
- dba_tables 和 dba_segments 表中块的区别
- dba_tables.blocks V$ dba_segments.blocks
- Dba_Segments .blocks=Dba_Tables.Blocks+Dba_Tables.Empty_Blocks ?
- dba_tables和dba_segments里记录的表大小的比较
- dba_tables、all_tables和user_tables的区别
- DBA_TABLES之BLOCKS AND EMPTY_BLOCKS
- 关于DBA_TABLES中SECONDARY列的含义
- dba_segments 查看表使用的容量
- tab-user_tables-dba_tables区别
- 在存储过程中查询dba_tables表的时候,需要赋权限给该用户
- oracle关于DBA_TABLES、ALL_TABLES以及USER_TABLES的区别
- dba_segments
- DBA_SEGMENTS
- dba_tables表中的num_rows与count(*)的值为何不同
- NSAutoreleasePool 和 @autoreleasepool blocks 区别
- popwindow 大全
- jQuery插件开发全解析
- jQuery.extend 函数详解
- 企业管理器(OEM)介绍: Grid Control 和 Database Control
- jquery的.live()和.bind的使用
- dba_tables 和 dba_segments 表中 blocks 的区别
- 在window下安装memcache实例
- NET性能优化方面的总结
- Apache的RewriteRule规则详细介绍
- 值类型与引用类型的性能差别
- Oracle Dedicated server 和 Shared server(专用模式 和 共享模式) 说明
- Apache Rewrite实现URL的跳转和域名跳转
- 404重定向设置
- apache 403错误