说明Oracle表中的存储参数initial, next, pctfree, pctused的含义。针对只做批量装载,没有update的数据仓库事实表,这些参数的设置原则。
initial, 建立这个表的时候初始化分配的空间
next, 空间不够的话,下一次扩展的空间大小
pctfree, 给这个表分配空间的时候对于初始分配的空间至少要预留的百分数,(对仓库来说,需要的空闲不用很多)
pctused, 给这个表分配空间的时候对于初始分配的空间最多可以使用的百分数,
可用于:表空间、回滚段、表、索引、分区、快照、快照日志

建议PCTINCREASE参数设置为0,可使碎片最小化,使每一个Extent都相同(等于NEXT值) 一旦建立了某个对象,它的INITIAL和MINEXTENTS参数不能修改(Oracle 816中可修改MINEXTENTS参数) 对于NEXT和PCTINCREASE的任何修改都只影响后来分配的那些Extent 在分配一个新Extent时,系统直接按NEXT的值分配一个Extent, 然后用公式:前一NEXT值*(1+PCTINCREASE/100) 计算出下一个应该分配的Extent的大小, 并把计算结果保存到相关数据字典的NEXT_EXTENT列上,做为下一个应该分配的Extent的大小。
CREATE TABLE test(a number) STORAGE( INITIAL 100K NEXT 100K MINEXTENTS 2 MAXEXTENTS 100 PCTINCREASE 100); |
解释: 初始给test表分配两个Extent, 第一个Extent是100K,因INITIAL=100K; 第二个Extent是100K,因NEXT=100K; 如果因表内数据增长,需要分配第三个Extent,因PCTINCREASE是100,则 第三个Extent是200K=100K+100K; 第四个Extent是400K=200K+200K。 可通过数据字典表DBA_TABLES、ALL_TABLES、USER_TABLES查看参数设置情况,如:
select table_name,initial_extent,next_extent, min_extents,max_extents,pct_increase from user_tables; TABLE_NAME INITIAL_EXTENT NEXT_EXTENT MIN_EXTENTS MAX_EXTENTS PCT_INCREASE ---------- -------------- ----------- ----------- ----------- ------------ TEST 106496 212992 2 100 100 |
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/7724693/viewspace-981089/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/7724693/viewspace-981089/