同事反映的一个错误ORA-01144

刚同事反映一个错误,上网查资料发现:
ORA-01144:文件大小(7680000块)超出4194303块的最大数
其中db_block_size=8k,单个数据文件最大应该是4194303个block,也就是8k*4194303=32G-8KB,解决方法可以建立多个小
的数据文件而不是建一个大的数据文件:
metalink解释:
Specify a smaller file size.
The maximum file size is
 db_block_size * 4194303
For example, if db_block_size is 2kB then maximum file size is limited
 to 2k*4194303, 8Gb-2k.
Change db_block_size. This can only be done by recreating of
 database.

 db_block_size Maximum data file size
 ------------- ----------------------
 2kb 8Gb-2kb
 4kb 16Gb-4kb
 8kb 32Gb-8kb
 16kb 64Gb-16kb
 32kb 128Gb-32kb
关于rowid:
rowid在磁盘上需要10 个字节(byte)的存储空间并使用18 个字符来显示它包含下列组件:
数据对象编号:每个数据对象如表或索引在创建时都分配有此编号,并且此编号在数据库中是唯一的;
相关文件编号:此编号对于一个表空间中的每个文件是唯一的;
块编号:表示包含此行的块在文件中的位置;
行编号:标识块头中行目录位置的位置;
在内部数据对象编号需要32位(bit),相关文件编号需要10位(bit),块编号需要22位(bit),位行编号需要16位,加起来
总共是80位或10 个字节,ROWID 使用以64为基数的编码方案来显示该方案将6个位置用于数据对象,编号3个位置用于相
关文件编号,6个位置用于块编号,3个位置用于行编号以64为基数的编码方案使用字符A-Z a-z 0-9 + 和/共64 个字符,如
下例所示:
AAAB/R AAB AAAGmS AAA
由于block是22位(bit),
22bit就是一个22位二进制数,换算成十进制就是 2的22次方-1=4194303 也就是说,一个datafile最多容纳这么多个blocks
数据块大小(block size)为2K的数据文件的size最大只能是8G
而依此类推8K数据块的一个数据文件的最大size只能是32G
解决方法为:
1)创建一个类似的表空间
2)直接在原来的表空间增加表数据文件,扩展表空间大小

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/24496749/viewspace-723266/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/24496749/viewspace-723266/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值