龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 数据库类 > Oracle 技术 >

Oracle数据文件的大小限制方案介绍

时间:2011-04-12 23:18来源:未知 作者:admin 点击:
分享到:
以下文章主要是对 Oracle 数据文件的大小限制的方案的介绍,我们都知道racle数据文件的大小的存在限制与一个内部的,这个相关的限制就是:每个相关数据文件在最多的情况下只能包含

以下文章主要是对Oracle数据文件的大小限制的方案的介绍,我们都知道racle数据文件的大小的存在限制与一个内部的,这个相关的限制就是:每个相关数据文件在最多的情况下只能包含2^22-1个数据块。

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

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

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

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

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

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

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

上周在做2K block_size测试时,第一次遇到了这个限制:

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 块的最大数

缩减一点,最后创建成功:

  1. SQL> alter tablespace eygle add datafile 'f:\eygle02.dbf' size 8191M reuse;  

表空间已更改。

已用时间: 00: 44: 42.08

计算一下,这台破烂的测试机的IO速度:

  1. io speed = 8191 M / 00: 44: 42.08 = 8191 M / 44*60+42 = 8191M / 2682 s = 3.05M/s 

上述的相关内容就是对Oracle数据文件大小的限制的描述,希望会给你带来一些帮助在此方面。

精彩图集

赞助商链接