oracle中用创建表时Storage中参数的含义

王朝oracle·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

点击查看大图

可用于:表空间、回滚段、表、索引、分区、快照、快照日志

建议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 106496212992 2 100100

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航