dba_tables和dba_segments表中blocks的区别

原 dba_tables 和 dba_segments 表中 blocks 的区别https://blog.csdn.net/tianlesoftware/article/details/5697331版权声明: https://blog.csdn.net/tianlesoftware/article/details/5697331
  创建测试表:
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://www.cndba.cn/Dave/article/1595
    查看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.
  ------------------------------------------------------------------------------ 
QQ: 492913789
Email: ahdba@qq.com
Blog: http://www.cndba.cn/dave
网上资源: http://tianlesoftware.download.csdn.net 
相关视频:http://blog.csdn.net/tianlesoftware/archive/2009/11/27/4886500.aspx 
DBA1 群:62697716(满); DBA2 群:62697977https://img-blog.csdnimg.cn/20190217105710569.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTEwNzgxNDE=,size_16,color_FFFFFF,t_70《算法导论 第三版英文版》_高清中文版.pdf
https://pan.baidu.com/s/17D1kXU6dLdU0YwHM2cvNMw
《深度学习入门:基于Python的理论与实现》_高清中文版.pdf
https://pan.baidu.com/s/1IeVs35f3gX5r6eAdiRQw4A
《深入浅出数据分析》_高清中文版.pdf
https://pan.baidu.com/s/1GV-QNbtmjZqumDkk8s7z5w
《Python编程:从入门到实践》_高清中文版.pdf
https://pan.baidu.com/s/1GUNSg4mdpeOf1LC_MjXunQ
《Python科学计算》_高清中文版.pdf
https://pan.baidu.com/s/1-hDKhK-7rDDFll_UFpKmpw

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

redelego@cloud

XXXXXXXXXXXXXXX

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值