如何设置oracle的数据包大小限制,[转载]Oracle中数据文件大小的限制

Oracle数据库存在每个数据文件大小的内部限制,由Rowid中的22位Block号决定,导致最大约为8G(2K Block_size)或16*8G(32K Block_size)。Oracle10g引入大文件表空间,使用32位Block号,允许每个文件最多容纳4G个Block,因此在2K Block_size下可达8T,32K Block_size下可达128T。在实践中,尝试创建8192M的数据文件因超过限制失败,缩减到8191M后成功创建。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Oracle数据文件的大小存在一个内部限制,这个限制是:

每个数据文件最多只能包含2^22-1个数据块。

这个限制也就直接导致了每个数据文件的最大允许大小。

在2K Block_size下,数据文件最大只能达到约8G

在32K的Block_size下,数据文件最大只能达到约16*8G的大小。

这个限制是由于Oracle的Rowid中使用22位来代表Block号,这22位最多只能代表2^22-1个数据块。

为了扩展数据文件的大小,Oracle10g中引入了大文件表空间,在大文件表空间下,Oracle使用32位来代表Block号,也就是说,在新的技术下,大文件表空间下每个文件最多可以容纳4G个Block。

那么也就是说当Block_size为2k时,数据文件可以达到8T 。

当block_size为32K时,数据文件可以达到128T。

上周在做时,第一次遇到了这个限制:SQL> alter tablespace eygle add datafile 'f:\eygle02.dbf' size 8192M;

alter tablespace eygle add datafile 'f:\eygle02.dbf' size 8192M

*

ERROR 位于第 1 行:

ORA-01144: 文件大小 (4194304 块) 超出 4194303 块的最大数

缩减一点,最后创建成功:SQL> alter tablespace eygle add datafile 'f:\eygle02.dbf' size 8191M reuse;

表空间已更改。

已用时间: 00: 44: 42.08

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值