表空间的初始大小分配
来源:互联网 发布:大数据监控系统 编辑:程序博客网 时间:2024/06/05 00:17
转自:http://blog.csdn.net/xfblue2dreamfy/article/details/6252437
今天进行表空间创建的时候,由于参考生产库的表空间使用是100G。此处我就用64G来作为初始表空间。
结果,抛出如下错误:
SQL> create tablespace IDX_ARC
2 datafile '/oradata2/alpha180/IDX_ARC001.DBF'
3 size 65536M extent management local
4 segment space management auto;
create tablespace IDX_ARC
datafile '/oradata2/alpha180/IDX_ARC001.DBF'
size 65536M extent management local
segment space management auto
ORA-01144: File size (8388608 blocks) exceeds maximum of 4194303 blocks
AIX 64位的平台
下面是oracle err messages:
Action: Specify a smaller size.
开始以为是操作系统的限制导致的,但是查了一下,没看到相关的限制(都已经-1了)
具体原因是什么呢?(如下为转载)
这要从Oracle的伪列rowid说起,话说.....
先看看关于rowid一段文章就明白了:(关于什么是rowid请baidu)
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。
再次执行,把表空间的初始值调为30G。ok,正常。
- 表空间的初始大小分配
- 表空间的初始大小分配
- ArrayList、HashMap等初始空间大小
- 结构体中成员大小的空间分配
- 当为指针分配0大小的空间会怎样
- 新建数据文件的初始大小
- 设置QDockWidget的初始大小
- 查看表空间的大小
- 可分配的空间分配
- mongodb手动预分配空间大小
- 线段树分配空间大小问题
- ArrayList的初始容量和容量分配
- 指针分配的空间
- 可恢复的空间分配
- 类的空间分配
- Java堆初始大小的建议值
- QDockWidget设置初始大小的一个解决方案
- QDockWidget设置初始大小的一个解决方案
- 史上第一次,AI能够自学翻译地球上的任何语言了
- Eclipse中打包maven项目-war包方式
- 移动端布局
- 第五届图灵杯1872PJ的情书
- C++网络(四)持续处理请求的C/S网络
- 表空间的初始大小分配
- 以太网,IP,TCP,UDP数据包分析
- 数据结构实验之图论十:判断给定图是否存在合法拓扑序列
- 富文本编辑器中按CTRL+ENTER键直接保存没有验证
- elasticseach基础
- [20]_怎么看STM32的哪些引脚是否兼容5V?
- 世界互联网大会溢出效应:比大佬饭局更值得关注的是产业互联网
- cortex m7 架构 随笔
- java第三篇 泛型的了解与使用