社区
基础和管理
帖子详情
如何估计一个表占用多少block?
kind01
2006-11-07 04:17:18
我有张表:
create table test(col varchar2(100))
其中有1w条记录,db_block_size=8k,oracle9i,请问如何估算这张表将占用多少个blocks?
现在想通过这1w条记录去估算20w条类似的记录占用表空间多大.
谢谢有这方面经验的高手指教(不知道有没有公式计算),谢谢!
...全文
386
12
打赏
收藏
如何估计一个表占用多少block?
我有张表: create table test(col varchar2(100)) 其中有1w条记录,db_block_size=8k,oracle9i,请问如何估算这张表将占用多少个blocks? 现在想通过这1w条记录去估算20w条类似的记录占用表空间多大. 谢谢有这方面经验的高手指教(不知道有没有公式计算),谢谢!
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
12 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
kind01
2006-11-08
打赏
举报
回复
是的,谢谢wiler(@_@) ,就想问问怎样更精确地进行估算
wiler
2006-11-08
打赏
举报
回复
pctfree和pctused是可调整的
你要精确计算的话,就要考虑这个在内
另外如果因为pctfree设置不当,而导致出现行链接,那更加难以精确计算
wiler
2006-11-08
打赏
举报
回复
pctfree=(average row size-initial row size)*100/average row size
pctused=(100-pctfree) -average row size * 100/availabe data space
oracle的其中一个优点时它可以管理每个表空间中的自由空间。oracle负责处理表和索引的空间管理,这样就可以让我们无需懂得oracle的表和索引的内部运作。不过,对于有经验的oracle调优专家来说,他需要懂得oracle是如何管理表的extent和空闲的数据块。对于调整拥有高的insert或者update的系统来说,这是非常重要的。
要精通对象的调整,你需要懂得freelists和freelist组的行为,它们和pctfree及pctused参数的值有关。这些知识对于企业资源计划(erp)的应用是特别重要的,因为在这些应用中,不正确的表设置通常是dml语句执行慢的原因。
对于初学者来说,最常见的错误是认为默认的oracle参数对于所有的对象都是最佳的。除非磁盘的消耗不是一个问题,否则在设置表的pctfree和pctused参数时,就必须考虑平均的行长和数据库的块大小,这样空的块才会被有效地放到freelists中。当这些设置不正确时,那些得到的freelists也是"dead"块,因为它们没有足够的空间来存储一行,这样将会导致明显的处理延迟。
freelists对于有效地重新使用oracle表空间中的空间是很重要的,它和pctfree及pctused这两个存储参数的设置直接相关。如果将pctused设置为一个高的值,这时数据库就会尽快地重新使用块。不过,高性能和有效地重新使用表的块是对立的。在调整oracle的表格和索引时,需要认真考虑究竟需要高性能还是有效的空间重用,并且据此来设置表的参数。以下我们来看一下这些freelists是如何影响oracle的性能的。
当有一个请求需要插入一行到表格中时,oracle就会到freelist中寻找一个有足够的空间来容纳一行的块。你也许知道,freelist串是放在表格或者索引的第一个块中,这个块也被称为段头(segment header)。pctfree和pctused 参数的唯一目的就是为了控制块如何在freelists中进出。虽然freelist link和 unlink是简单的oracle功能,不过设置freelist link (pctused) 和unlink (pctfree) 对oracle的性能确实有影响。
由dba的基本知识知道,pctfree参数是控制freelist un-links的(即将块由freelists中移除)。设置pctfree=10 意味着每个块都保留10%的空间用作行扩展。pctused参数是控制freelist re-links的。设置pctused=40意味着只有在块的使用低于40%时才会回到表格的freelists中。
许多新手对于一个块重新回到freelists后的处理都有些误解。其实,一旦由于一个删除的操作而令块被重新加入到freelist中,它将会一直保留在freelist中即使空间的使用超过了60%,只有在到达pctfree时才会将数据块由freelist中移走。
kind01
2006-11-08
打赏
举报
回复
一个块要减去标头(90bytes)和pctfree(10%)才是可用的
wiler
2006-11-08
打赏
举报
回复
select 10000/((8192-90)*0.9/avglen) blocks from dual
这个是否应该是这样:
select 10000*avglen/1024/8192 blocks from dual
不理解((8192-90)*0.9)这个是什么意思
kind01
2006-11-07
打赏
举报
回复
我有这样的方法:
select avg(vsize(col1)+vsize(col2)) avglen from table1
select 10000/((8192-90)*0.9/avglen) blocks from dual
发现这个blocks有点不太准确
wiler
2006-11-07
打赏
举报
回复
select table_name,sum( decode( substr(data_type,1,1),
'N',nvl(data_precision,38),
'D',7,data_length) ) max_row_length
from dba_tab_columns
where owner='USER_NAME'
group by table_name
取得最大行长(单位:字节),再乘以1w,除以1024,再除以8k得到blocks数
kind01
2006-11-07
打赏
举报
回复
谢谢大家,也许你们理解错了我的意思,我的意思应该是这样的:假如给你一W条记录,告诉你这些记录的字段类型及个数,能不能估算这一W条记录大概占多少个blocks.实践我现在没有数据,只想粗略地估算一下.
SIRIUS_ORA
2006-11-07
打赏
举报
回复
select blocks from dba_extents
where owner = 'owner_name'
and tablespace_name = 'tablespace_name'
and segment_name = 'table_name';
当然了你的有dba的权限
xiaoxiao1984
2006-11-07
打赏
举报
回复
或者仔细一点,楼主需要根据平均一条记录占据的字节数,计算出20w数据占据的字节数,然后根据db_block_size,相除得到blocks
因为只是估算,而且已经有了大概1w的数据的blocks,偷懒一点拉
kind01
2006-11-07
打赏
举报
回复
这样也太粗糙了吧
xiaoxiao1984
2006-11-07
打赏
举报
回复
analyze table tab_name compute statistics;
select blocks as 占用blocks,empty_blocks as 空的blocks from user_all_tables where table_name = upper(&&tab_name) ;
粗略估算的话,blocks * 20 应该是将可能占用的blocks
区块链综合高级实战培训
各个区块之间通过随机散列(也称哈希算法)实现链接,后一个区块包含前一个区块的哈希值,随着信息交流的扩大,一个区块与一个区块相继接续,形成的结果就叫区块链 6 。 什么是区块链?从科技层面来看,区块链...
Linux 中每个 TCP 连接最少
占用
多少内存?
关于“Linux 中每个 TCP 连接
占用
多少内存”这一问题,中文网络上流传一种说法:TCP 连接建立的时候会分配接收缓冲区和发送缓冲区,各 4KB,一共是 8KB。如果加上 TCP 协议控制块(protocol control
block
)的 2KB,一共是 10KB,并且用 tcp_rmem 和 tcp_wmem 的值来佐证这个观点。这种说法是错误的。$ sysctl -A |grep tcp...
小文件存到HDFS
占用
空间是文件实际大小,而非一个
block
块的大小
想起一个问题: 如果一个HDFS上的文件大小(file size) 小于块大小(
block
size) ,那么HDFS会实际
占用
Linux file system的多大空间?是128M吗(hadoop2.7.3版本开始默认
block
大小都是128M) 答案:
占用
的是实际的磁盘存储,而非一个
block
块的大小 补充块大小的作用 1、块大小更多是逻辑概念,指导存储规划和空间申请的 2、当文件通过append操作不断增长的过程中,可以通过来
block
size决...
Linux如何查看目录
占用
空间大小?
但是大家会发现,在使用ls -r命令查看目录大小时,目录的大小多数是4kb,这是因为目录下的子目录名和子文件名是保存到父目录的
block
中的,如果父目录下的子目录和子文件并不多,一个
block
就能放下,那么这个父目录就只
占用
一个
block
大小。但是我们在统计目录时,不是想看父目录下的子目录名和子文件名到底
占用
了多少空间,而是想看父目录下的子目录和子文件的总磁盘
占用
量大小,这时就需要使用du命令才能统计目录的真正磁盘
占用
量大小。-a 显示目录
占用
的磁盘空间大小,还要显示其下目录和文件
占用
磁盘空间的大小。
如何计算Oracle的
表
一条记录
占用
空间的大小?
如何计算Oracle的
表
一条记录
占用
空间的大小? 如何计算Oracle的
表
记录
占用
空间的大小? 是把所有字段的大小都加起来吗?varchar(256),char,number算几个字节? ——解决方案——————– 第一行的列头信息所占字节数,再加上各个字段所占的字节数据,加起来是多少就是多少 列头信息记录每个字段的数据类型 ——解决方案——————– 1,你可以对
表
进行分析,然后在...
基础和管理
17,377
社区成员
95,127
社区内容
发帖
与我相关
我的任务
基础和管理
Oracle 基础和管理
复制链接
扫一扫
分享
社区描述
Oracle 基础和管理
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章