您好,欢迎访问一九零五行业门户网

Oracle 11g的Deferred Segment Creation

本篇主要介绍oracle 11g中推出的ldquo;延迟段创建rdquo;(deferred segment creation)特性,以及当我们使用这种特性时,需要注
本篇主要介绍oracle 11g中推出的“延迟段创建”(deferred segment creation)特性,,以及当我们使用这种特性时,需要注意的问题。
1)deferred segment creation
在oracle中,“表空间(tablespace)、段(segment)、分区(extent)和块(block)”是逻辑存储结构的四个层次。对数据表而言,通常是由一个或者多个段对象(分区表)segment组成。也就是说,在数据表创建的时刻,oracle会创建一个数据段segment对象与之对应。
当segment创建之后,oracle空间管理机制会根据需要分配至少一个extent作为初始化。每个extent的大小需要根据不同tablespace进行配置。但是在11g之前,数据表的创建同时,就发生了空间segment分配的过程。但是在oracle 11g中,引入了deferred segment creation特性。
首先我们创建一个数据表justfortest,来观察数据库是否为此表分配segment。
sqljustfortest(test1 varchar2(2));table created
但是,对应的段segment对象,却没有创建出来,如下:
;segment_name bytesblocks extents------------ ---------- ---------- ----------
使用dbms_metadata抽取出数据表的ddl语句,可以发现端倪,如下:
create table test.justfortest( test1 varchar2(2)) segment creation deferredpctfree 10 pctused 40 initrans 1 maxtrans 255 nocompress logging tablespace testns;
使用ddl语句可以获取到创建数据表的所有语句参数,包括默认参数。其中,我们发现了一个在过去版本中没有参数“segment creation deferred”,该参数就表示在数据表创建中使用延迟段生成。
2)segment creation
那么,在什么时点上oracle才会创建对象呢?只要插入一条数据到数据表中,无论是否commit,都会伴随着oracle对数据表段的创建操作。
sqljustfortest );1 row insertedsql;segment_name bytesblocks extents------------ ---------- ---------- ----------justfortest 
oracle推出deferred segment creation的出发点很单纯,就是出于对象空间节省的目的。如果一个空表从来就没有使用过,创建segment对象,分配空间是“不合算”的,所以提出推迟段创建的时间点。
sql> show parameter deferred_segment_creation;nametypevalue------------------------------- ----------- ------------------------------deferred_segment_creationbooleantrue
当然,我们可以将deferred_segment_creation参数调为false,这样调整后建的表都会立即分配空间,但是调整前的表都不会改变,调整方法如下:
alter system set deferred_segment_creation=false;
3)oracle 11g导出空表、少表的解决办法
如果deferred_segment_creation为true,那么数据库中空表就不会立即分配extent,即不占数据空间,当我们使用exp导出数据库的时候,这些空表也会无法导出。如果想把空表也一起导出,我们可以参考oracle 11g导出空表、少表的解决办法这篇文章。
在centos 6.4下安装oracle 11gr2(x64)
oracle 11gr2 在vmware虚拟机中安装步骤
debian 下 安装 oracle 11g xe r2
oracle linux 6.5安装oracle 11.2.0.4 x64
本文永久更新链接地址:
其它类似信息

推荐信息