新客网WWW.XKER.COM:致力做中国最专业的网络学院!
学院: 操作系统 - 网络应用 - 服务器 - 网络安全 - 工具软件 - 办公软件 - Web开发 - 数据库 - 网页设计 - 图形图像 - 媒体动画 - 硬件学堂 - 存储频道 - QQ专区
您的位置:首页 > 软件开发 > 数据库 > Oracle教程 > 正文:讲解Oracle创建表时Storage参数具体含义

讲解Oracle创建表时Storage参数具体含义

新客网 XKER.COM 2007-07-11 来源: changelive 收藏本文

本文通过图表和实例的阐述在Oracle数据库创建新表时Storage的参数具体含义。

图表阐述 

 

 

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

 

 

 

建议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
收藏】 【评论】 【推荐】 【投稿】 【打印】 【关闭
发表评论
要记得去论坛讨论,点击注册新会员匿名评论
评论内容:不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
阅读排行
随机推荐
实用信息推荐