Oracle分区表,各分区使用同一个表空间与不同表空间的性能比较,的性能比较,哪个性能更好?或是性能一样

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle分区表,各分区使用同一个表空间与不同表空间的性能比较,的性能比较,哪个性能更好?或是性能一样相关的知识,希望对你有一定的参考价值。

如下面语句所创建的两个表,请问wf_part1与wf_part2哪一个表的性能会好一些
//////////////////////1111111111111111111111111111111111111111
create table wf_part1
(
wf_id integer primary key,
wf_date date,
wf_dec varchar2(50)
)TABLESPACE userdata
partition by range(wf_date)(
partition part_01 values less than(to_date('2006-01-01','yyyy-mm-dd')) tablespace wf1,
partition part_02 values less than(to_date('2007-01-01','yyyy-mm-dd')) tablespace wf2,
partition part_03 values less than(maxvalue) tablespace userdata);
/////////////222222222222222222222222222222222
create table wf_part2
(
wf_id integer primary key,
wf_date date,
wf_dec varchar2(50)
)TABLESPACE userdata
partition by range(wf_date)(
partition part_01 values less than(to_date('2006-01-01','yyyy-mm-dd')) tablespace wf1,
partition part_02 values less than(to_date('2007-01-01','yyyy-mm-dd')) tablespace wf1,
partition part_03 values less than(maxvalue) tablespace wf1);

分区表使用不同的表空间,可以很显著的提高数据的读写速度,前提是各表空间分属不同的物理磁盘,如果在同一个磁盘,效果不大。望采纳。来自:求助得到的回答 参考技术A 这还要看低层存储情况。就你举的例子来说,如果表空间wf1和wf2是在同一块物理磁盘上,那么我感觉和分区在同一个表空间wf1的性能差不多;如果表空间wf1和wf2是放在不同的物理磁盘上,那性能会有很大提升。 参考技术B 不同分区分布到不同磁盘上,可以降低I/O冲突
可以将不同分区分布到同一表空间的不同数据文件上,数据文件要分布到不同磁盘上,这样才有效果。本回答被提问者采纳

Oracle中分区表中表空间属性

Oracle中的分区表是Oracle中的一个很好的特性,可以把大表划分成多个小表,从而提高对于该大表的SQL执行效率,而各个分区对应用又是透明的。

分区表中的每个分区有独立的存储特性,包括表空间、PCT_FREE等。那分区表中的各分区表空间之间有什么关系?新建的分区会创建在哪个表空间中呢?对应的local分区索引又会使用哪个表空间呢?下面使用一个例子来解释上面的这些问题。

创建测试分区表:

[email protected]>create table t (id number,name varchar2(10))
  2  tablespace users
  3  partition by range(id)
  4  (
  5  partition p1 values less than (10) tablespace example,
  6  partition p2 values less than (20) tablespace system,
  7  partition p3 values less than (30)
  8  );

上面创建了一个range分区表T,对表T指定了表空间为users,分区p1表空间为example,分区p2表空间为system,分区p3表空间没有指定。

下面分别从user_tables、user_tab_partitions视图中查看对应的表空间

[email protected]>col tablespace_name for a30
[email protected]>col partition_name for a30
[email protected]>select tablespace_name,partitioned from user_tables where table_name=‘T‘;

TABLESPACE_NAME 	       PARTITION
------------------------------ ---------
			       YES

[email protected]>select partition_name,tablespace_name from user_tab_partitions where table_name=‘T‘;

PARTITION_NAME		       TABLESPACE_NAME
------------------------------ ------------------------------
P1			       EXAMPLE
P2			       SYSTEM
P3			       USERS

从上面的查询可以看出,分区表T在user_tables视图中没有记录表空间名的信息,分区P1和P2对应的分区与建表语句中指定的一致,分区P3对应的分区与表T指定的表空间一致为USERS。难道表T就没有表空间属性么?我们使用dbms_metadata.get_ddl查看表T的语句:

技术分享

从上图中可以看出表T其实也是有表空间属性的,就是在建表时指定的USERS表空间。而分区P3继承了这一属性。那为什么说是分区P3继承了这一属性呢,我们查询下面的视图:

[email protected]>col table_name for a30
[email protected]>select table_name,def_tablespace_name from user_part_tables;

TABLE_NAME		       DEF_TABLESPACE_NAME
------------------------------ ---------------------------------
T			       USERS

官方文档对列def_tablespace_name的解释是Default tablespace to be used when adding a partition。从上面的查询可以知道,表T的分区如果没有明确指定表空间时都会使用USERS表空间。事实是这样么,下面给表T添加一个表空间:

[email protected]>alter table t add partition p4 values less than (40);

Table altered.

[email protected]>select partition_name,tablespace_name from user_tab_partitions where table_name=‘T‘;

PARTITION_NAME		       TABLESPACE_NAME
------------------------------ ------------------------------
P1			       EXAMPLE
P2			       SYSTEM
P3			       USERS
P4			       USERS

从上面可以看到,新添加的分区P4对应的表空间是USERS,证实了前面的观点。

如果当前的表空间已经无法扩展,想把新加的分区创建到其他表空间中,而在加表空间时不指定表空间信息,可以实现么?答案是肯定可以。

[email protected]>alter table t modify default attributes tablespace example;

Table altered.

[email protected]>select table_name,def_tablespace_name from user_part_tables;

TABLE_NAME		       DEF_TABLESPACE_NAME
------------------------------ ------------------------------------------------------------------------------------------
T			       EXAMPLE

[email protected]>alter table t add partition p5 values less than (50);

Table altered.

[email protected]>select partition_name,tablespace_name from user_tab_partitions where table_name=‘T‘;

PARTITION_NAME		       TABLESPACE_NAME
------------------------------ ------------------------------
P1			       EXAMPLE
P2			       SYSTEM
P3			       USERS
P4			       USERS
P5			       EXAMPLE

从上面可以看到在修改了表T的表空间属性后,新加的分区P5创建在EXAMPLE表空间中。

下面再来看local分区索引对应的表空间。先在表上创建一个分区索引。

[email protected]>create index idx_t on t(id) local;

Index created.

下面看看local分区索引对应的表空间的属性:

[email protected]>select tablespace_name,partitioned from user_indexes where index_name=‘IDX_T‘;

TABLESPACE_NAME 	       PARTITION
------------------------------ ---------
			       YES

[email protected]>select partition_name,partition_position,tablespace_name from user_ind_partitions where index_name=‘IDX_T‘;

PARTITION_NAME		       PARTITION_POSITION TABLESPACE_NAME
------------------------------ ------------------ ------------------------------
P1						1 EXAMPLE
P2						2 SYSTEM
P3						3 USERS
P4						4 USERS
P5						5 EXAMPLE

从上面的查询可以看出,local分区索引上没有表空间信息,而每个索引分区对应的表空间名与相应的分区所在的表空间一致。我们同样使用dbms_metadata包来查看索引的建表语句:

技术分享从上图可以看到索引IDX_T确实没有表空间属性。我们再来查看user_part_index来验证一下是否是真的呢:

[email protected]>col index_name for a30
[email protected]>col def_tablespace_name for a30
[email protected]>select index_name,def_tablespace_name from user_part_indexes where index_name=‘IDX_T‘;

INDEX_NAME		       DEF_TABLESPACE_NAME
------------------------------ ------------------------------
IDX_T

从上面的查询中可以看到索引IDX_T也没有默认的表空间存储选项,而在官方文档中看到:New partitions or subpartitions added to the local index will be created in the same tablespace(s) as the corresponding partitions or subpartitions of the underlying table。说明local分区索引默认与相关联的表分区在同一个表空间,上面的查询也可以验证这一结论。那可以把local分区索引所在的表空间与表分区所在的表空间分开来么?答案是肯定可以的。在创建本地索引进指定表空间参数即可:

[email protected]>drop index idx_t;

Index dropped.

[email protected]>create index idx_t on t(id) local tablespace sysaux;

Index created.

[email protected]>select tablespace_name,partitioned from user_indexes where index_name=‘IDX_T‘;

TABLESPACE_NAME 	       PARTITION
------------------------------ ---------
			       YES
			       
[email protected]>select partition_name,partition_position,tablespace_name from user_ind_partitions where index_name=‘IDX_T‘;

PARTITION_NAME		       PARTITION_POSITION TABLESPACE_NAME
------------------------------ ------------------ ------------------------------
P1						1 SYSAUX
P2						2 SYSAUX
P3						3 SYSAUX
P4						4 SYSAUX
P5						5 SYSAUX

[email protected]>select index_name,def_tablespace_name from user_part_indexes where index_name=‘IDX_T‘;

INDEX_NAME		       DEF_TABLESPACE_NAME
------------------------------ ------------------------------
IDX_T			       SYSAUX

从上面的查询中可以看到所有的分区索引的表空间都为SYSAUX。

创建一个新的分区,看对应的分区索引是否还是在SYSAUX表空间:

[email protected]>alter table t add partition p6 values less than (60);

Table altered.

[email protected]>select partition_name,partition_position,tablespace_name from user_ind_partitions where index_name=‘IDX_T‘;

PARTITION_NAME		       PARTITION_POSITION TABLESPACE_NAME
------------------------------ ------------------ ------------------------------
P1						1 SYSAUX
P2						2 SYSAUX
P3						3 SYSAUX
P4						4 SYSAUX
P5						5 SYSAUX
P6						6 SYSAUX

从上面可以看出新的分区索引所在的表空间仍是SYSAUX。

下面来看如何修改新分区索引创建的对应的表空间:

[email protected]>alter index idx_t modify default attributes tablespace users;

Index altered.

[email protected]>select index_name,def_tablespace_name from user_part_indexes where index_name=‘IDX_T‘;

INDEX_NAME		       DEF_TABLESPACE_NAME
------------------------------ ------------------------------
IDX_T			       USERS

[email protected]>alter table t add partition p7 values less than (70);

Table altered.

[email protected]>select partition_name,partition_position,tablespace_name from user_ind_partitions where index_name=‘IDX_T‘;

PARTITION_NAME		       PARTITION_POSITION TABLESPACE_NAME
------------------------------ ------------------ ------------------------------
P1						1 SYSAUX
P2						2 SYSAUX
P3						3 SYSAUX
P4						4 SYSAUX
P5						5 SYSAUX
P6						6 SYSAUX
P7						7 USERS

从上面的结果可以看出,新加分区对应的分区索引的表空间变为了新指定的USERS。修改成功。



本文出自 “DBA Fighting!” 博客,请务必保留此出处http://hbxztc.blog.51cto.com/1587495/1929585

以上是关于Oracle分区表,各分区使用同一个表空间与不同表空间的性能比较,的性能比较,哪个性能更好?或是性能一样的主要内容,如果未能解决你的问题,请参考以下文章

Oracle表分区

oracle表分区

Oracle 表分区

ORACLE表索引和分区

oracle 表分区例子

oracle 的 impdp 命令如何将数据导入到指定表空间的指定数据文件中