提示ORA-01144: File size (13107200 blocks) exceeds maximum of 4194303 blocks

在imp导入一个超大库的时候出现这问题。
经过检查并非磁盘问题大小问题。
而是oracle本身数据块问题。

rowid在磁盘上需要10 个字节(byte)的存储空间并使用18 个字符来显示它包含下列组件:数据对象编号,相关文件编号,块编号,行编号
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

2K数据库的数据文件的size最大只能是8G
而依此类推8K数据块的一个数据文件的最大size只能是32G

解决方法


alter tablespace USERS add datafile 'add.dbf' size 30g;

 

当然也可以在建表空间选择建大表空间

‘CREATE BIGFILE TABLESPACE “‘ space'” LOGGING DATAFILE ”’ space_01.dbf” SIZE 50G REUSE AUTOEXTEND ON NEXT 500M MAXSIZE UNLIMITED EXTENT MANAGEMENT LOCAL AUTOALLOCATE SEGMENT SPACE MANAGEMENT AUTO’;

 

 

关于表空间和数据文件

http://blog.csdn.net/leshami/article/details/5611738