Oracle分区表的使用和管理在某些场合会使用非常大的表,比如人口信息统计表。如果一个表很大,就会降低查询的速度,并增加管理的难度。一旦发生磁盘损坏,可能整个表的数据就会丢失,恢复比较困难。根据...SyntaxHighlighter.all();
Oracle分区表的使用和管理
在某些场合会使用非常大的表,比如人口信息统计表。如果一个表很大,就会降低查询的速度,并增加管理的难度。一旦发生磁盘损坏,可能整个表的数据就会丢失,恢复比较困难。根据这一情况,可以创建分区表,把一个大表分成几个区(小段),对数据的操作和管理都可以针对分区进行,这样就可以提高
数据库的运行效率。分区可以存在于不同的表空间上,提高了数据的可用性。
1.使用分区的优点:
*增强可用性:如果表的某个分区出现故障,表在其他分区的数据仍然可用;
*维护方便:如果表的某个分区出现故障,需要修复数据,只修复该分区即可;
*均衡I/O:可以把不同的分区映射到磁盘以平衡I/O,改善整个系统性能;
*改善查询性能:对分区对象的查询可以仅搜索自己关心的分区,提高检索速度
2.表分区的依据
分区的依据可以是一列或多列的值,这一列或多列称为分区关键字或分区列。所有分区的逻辑属性是一样的(列名、数据类型、约束条件等),但每个分区可以有自己的物理属性(表空间、存储参数等)。
分区有四种:范围分区、哈希分区、列表分区和组合分区。
范围分区:根据分区关键字值的范围建立分区,将记录存放到列值所在的range分区中。比如,根据时间建立分区。
为各个分区建立独立的表空间
create tablespace test_space001 datafile'd:\tbs001.dbf' size20M;
create tablespace test_space002 datafile'd:\tbs002.dbf' size20M;
create tablespace test_space003 datafile'd:\tbs003.dbf' size20M;
建立分区表:
Create table range_example(
Range_key_column date,
Dat varchar2(20),
Id integer
)
Partition by range(range_key_column)
(
Partition part01 values less than(to_date(‘2013-8-28’,’yyyy-mm-dd’)) tablespace test_space01,
Partition part02 values less than(to_date(‘2013-9-28’,’yyyy-mm-dd’)) tablespace test_space02
Partition part03 values less than(maxvalue)) tablespace test_space03
)
如果某些记录暂时无法预测范围,可以创建maxvalue分区,所有不在指定范围内的记录都会被存储到Maxvalue所在分区中
在表分区上进行查询
Select * from range_example partition(part01);
哈希分区:对于那些无法有效划分范围的表,在分区列上使用HASH算法进行分区,这样对于提高性能还是会有一定的帮助。hash分区会将表中的数据平均分配到你指定的几个分区中,列所在分区是依据分区列的hash值自动分配,因此你并不能控制也不知道哪条记录会被放到哪个分区.
create table test
(
transaction_id number primary key,
item_id number(8) not null
)
partition by hash(transaction_id)
(
partition part_01 tablespace tablespace01,
partition part_02 tablespace tablespace02,
partition part_03 tablespace tablespace03
);
列表分区:根据预先定义好的分区键数值确定记录被分配到哪个分区。List分区也需要指定列的值,其分区值必须明确指定,该分区列只能有一个,不能像range或者hash分区那样同时指定多个列做为分区依赖列,但它的单个分区对应值可以是多个。 在分区时必须确定分区列可能存在的值,一旦插入的列值不在分区范围内,则插入/更新就会失败,因此通常建议使用list分区时,要创建一个default分区存储那些不在指定范围内的记录,类似range分区中的maxvalue分区。
create table custaddr
(
id varchar2(15 byte) not null,
areacode varchar2(4 byte)
)
partition by list (areacode)
( partition t_list025 values ('025'),
partition t_list372 values ('372') ,
partition t_list510 values ('510'),
partition p_other values (default)
)
组合分区:如果某表按照某列分区之后,仍然较大,或者是一些其它的需求,还可以通过分区内再建子分区的方式将分区再分区,即组合分区的方式。 组合分区在10g中有两种:range-hash,range-list。注意顺序,根分区只能是range分区,子分区可以是hash分区或list分区。在
Oracle 11g中,组合分区功能又增加了range-range,list-range,list-list,list-hash,并且 11g里面还支持Interval分区和虚拟列分区。
语法:
PARTITION BY RANGE (column_name1)
SUBPARTITION BY HASH (column_name2)
SUBPARTITIONS number_of_partitions
(
PARTITION part1 VALUE LESS THAN(range1),
PARTITION part2 VALUE LESS THAN(range2),
...
PARTITION partN VALUE LESS THAN(MAXVALUE)
);
应用:对时间字段按范围进行分区后每个分区的记录数仍然很多,可以按很少重复的列(月份)进行hash分区,这个可以使子分区的记录数目比较平衡
CREATE TABLE SALES
(
PRODUCT_ID VARCHAR2 (5),
SALES_DATE DATE NOT NULL,
SALES_COST NUMBER (10)
)
PARTITION BY RANGE (SALES_DATE)
SUBPARTITION BY HASH (PRODUCT_ID)
subpartitions 3 store in (tablespace01,tablespace02,tablespace03)
(
PARTITION S1 VALUES LESS THAN (TO_DATE(‘01/4月/2011','DD/MON/YYYY')),
PARTITION S2 VALUES LESS THAN (TO_DATE(‘01/7月/2011','DD/MON/YYYY')),
PARTITION S3 VALUES LESS THAN (MAXVALUE)
);