代码改变世界

_partition_large_extents和_index_partition_large_extents参数导致表空间增长快

2020-08-11 15:33  dba+  阅读(1212)  评论(0编辑  收藏  举报

    帮助客户使用expdp导入测试数据时,发现数据量快速增长,瞬间就撑满了表空间,测试库的数据明显多于生产数据库的数据,这是什么原因导致的呢。在网上差了一下才知道是_partition_large_extents参数导致的。从11.2.0.2开始,创建分区表,每个分区默认大小为8M,是由_partition_large_extents参数控制,可以算是11.2.0.2开始的一个新特性,为了减少extent数量,提高分区表性能,而设置的一个参数,默认为true,即分区表的每个extent为8M。测试一下:

确保deferred_segment_creation  参数为TURE的情况下测试_partition_large_extents参数。

SQL> show parameter defer

NAME                     TYPE     VALUE
------------------------------------ ----------- ------------------------------
deferred_segment_creation         boolean     TRUE

col name for a30 col value for a10 col describ for a60 set lines 300 SELECT x.ksppinm NAME, y.ksppstvl VALUE, x.ksppdesc describ FROM SYS.x$ksppi x, SYS.x$ksppcv y WHERE x.inst_id = USERENV ('Instance') AND y.inst_id = USERENV ('Instance') AND x.indx = y.indx AND x.ksppinm='_partition_large_extents'; NAME VALUE DESCRIB ------------------------------ ---------- -------------------------------------------------- _partition_large_extents TRUE Enables large extent allocation for partitioned tables

创建分区表,注意要使用非system和sys表空间

SQL> conn  scott/tiger

SQL> create
table test_com_partition_1 ( id int not null, name varchar2(4000) ) partition by range(id) ( partition p10 values less than(10), partition p20 values less than(20), partition p30 values less than(30), partition p40 values less than(40), partition pmax values less than(maxvalue) );

SQL> select PARTITION_NAME,TABLESPACE_NAME from user_segments where SEGMENT_NAME='TEST_COM_PARTITION_1';

no rows selected

 

由于参数deferred_segment_creation为true,所以创建表以后并没有分配segments。下面插入数据

SQL> insert into test_com_partition_1 values (1,lpad('shengruxiahua',3900,'shengruxiahua'));

SQL> select TABLESPACE_NAME,PARTITION_NAME,bytes/1024/1024 from user_segments  where SEGMENT_NAME='TEST_COM_PARTITION_1';

TABLESPACE_NAME            PARTITION_NAME              BYTES/1024/1024
------------------------------ ------------------------------ ---------------
USERS                   P10                        8

只插入一行数据后segment大小是8M,可是不小啊,下面修改_partition_large_extents参数后再次进行测试

SQL> alter system set "_partition_large_extents"=

SQL> create table test_com_partition_2
(
id int not null,
name varchar2(4000)
)
partition by range(id)
(
partition p10 values less than(10), 
partition p20 values less than(20), 
partition p30 values less than(30), 
partition p40 values less than(40), 
partition pmax values less than(maxvalue)
);

SQL> insert into test_com_partition_2 values (1,lpad('shengruxiahua',3900,'shengruxiahua'));

SQL> select TABLESPACE_NAME,PARTITION_NAME,bytes/1024/1024 from user_segments  where SEGMENT_NAME='TEST_COM_PARTITION_2';

TABLESPACE_NAME            PARTITION_NAME              BYTES/1024/1024
------------------------------ ------------------------------ ---------------
USERS                   P10                    .0625 

    结论:当参数_partition_large_extents等于true时(此时可能不可见),创建分区表默认占用空间大小为每个分区8m,而普通表默认占据空间大小仅0.0625m(64k)。另外一个有关系的参数是_index_partition_large_extents,用于控制创建分区索引的大小,默认也是true,即默认分区索引大小为8m,而创建普通索引默认大小为64k。这里就不做实验了。

 

    还有一种情况对子分区的影响。,如果带有子分区,deferred_segment_creation虽然为true,但是在一个分区表中如果有一个子分区插入了记录,那么其他子分区会同时创建segment.对于数据量不多,而且数据大量集中在某几个分区,那强烈建议设置_partition_large_extents为false,节约空间.如果数据量较大,而且数据分布较为均匀,建议设置_partition_large_extents为true. 具体请参考惜分飞 老师的文章。

 

参考文章:

Initial Extent Size of a Partition Changed to 8MB from 64KB After Upgrade to 11.2.0.2 or Later (Doc ID 1295484.1)

https://www.cnblogs.com/wcwen1990/p/6656545.html

https://www.xifenfei.com/2013/08/%e5%88%86%e5%8c%ba%e9%bb%98%e8%ae%a4segment%e5%a4%a7%e5%b0%8f%e5%8f%98%e5%8c%9664k-8m.html