您的位置:首页 > 数据库 > Oracle

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

2009-10-29 22:46 351 查看
 

              

              直接看摘抄处的链接

建议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
本篇文章来源于 开发学院 http://edu.codepub.com/  原文链接:http://edu.codepub.com/2009/0914/15382.php

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  oracle table user