Oracle i以后推出了分区选项分区将表分离在若于不同的表空间上用分而治之的方法来支撑元限膨胀的大表组大表在物理一级的可管理性将大表分割成较小的分区可以改善表的维护备份恢复事务及查询性能
分区的具体优点
增强可用性如果表的一个分区由于系统故障而不能使用表的其余好的分区仍可以使用
减少关闭时间如果系统故障只影响表的一部份分区那么只有这部份分区需要修复可能比整个大表修复花的时间更少
维护轻松如果需要得建表独产管理每个公区比管理单个大表要轻松得多
均衡I/O可以把表的不同分区分配到不同的磁盘来平衡I/O改善性能
改善性能对大表的查询增加修改等操作可以分解到表的不同分区来并行执行可使运行速度更快在数据仓库的TP查询特别有用
分区对用户透明最终用户感觉不到分区的存在
列表分区表create table BS_CDR_WLAN_LOC_
(
DAY_NUMBER NUMBER() not null
……
TPREMARK VARCHAR()
)
partition by list (DAY_NUMBER)
(
partition P_BS_CDR_OTH_LOC_ values ()
partition P_BS_CDR_OTH_LOC_ values ()
……
partition P_BS_CDR_OTH_LOC_ values ()
)
按范围分区
注就是按一定range来分区
SQL> create table niegc_part
(
part_id integer primary key
part_date date
part_dec varchar()
)
partition by range(part_date)
(
partition part_ values less than(to_date(yyyymmdd))
partition part_ values less than(to_date(yyyymmdd))
partition part_ values less than(maxvalue)
)
Hash分区(散列分区)
散列分区通过指定分区编号来均匀分布数据的一种分区类型因为通过在I/O设备上进行散列分区使行这些分区大小一致
如将part_id的数据根据自身的情况散列地存放在指定的三个表空间中
create table niegc_part
(
part_id integer primary key
part_date date
part_dec varchar()
)
partition by hash(part_id)
(
partition part_ tablespace dw
partition part_ tablespace dw
)
复合分区
create table tab_students
(c_id number
c_name varchar()
c_age number
c_birthday date
c_nation varchar()
)
partition by range(c_id)
subpartition by list(c_nation)
SUBPARTITION TEMPLATE
(SUBPARTITION part_hanzu VALUES (汉族)
SUBPARTITION part_others VALUES (DEFAULT)
)
(
PARTITION part_id VALUES LESS THAN ()
PARTITION part_id VALUES LESS THAN ()
PARTITION part_id VALUES LESS THAN (MAXVALUE)
)
索引分区
注意 对某个字段已做了分区了是不允许再建立索引分区的这一点要非常注意
全局索引建立时global子句允许指定索引的范围值这个范围值为索引字段的范围值
create index idx_part_id on niegc_part(part_dec)
global partition by range(part_dec)
(
partition idx_ values less than() tablespace dw
partition idx_ values less than(maxvalue) tablespace dw
)
局部索引分区的建立
(注表必须存在分区此分区的个数必须和分区表的分区个数一样不然是建立不起来的)
create index idx_part_id on niegc_part(part_dec)
local
(
partition idx_ tablespace dw
partition idx_ tablespace dw
)
分区维护(只对范围分区)
()增加一个分区分区范围只能往上增不能增加一个少于原有的分区
alter table tablename add partition new_partitionname values less than(maxvalue)
()合并/拆分分区(合并后的分区必须指下最后一个大value的分区)
alter table tablename merge partitions partitionnamepartitionname into partition partitionname
alter table tablename split partition partitionname at (xx) into (
partition newpartition partition newpartition)
注意xx为分割点
()删除一个分区
alter table niegc_part drop partition partitionname
()将分区改名
alter table table_name rename Partition partition_name to partition_name
()将分区改表空间
alter table table_name move partition_name
tablespace tablespace_name nologging
()查询特定分区
select count(*) from table_name partition (partition_name)
()添加数据
insert into table_name select * from table_name partition (partition_name)
()分区表的导出
userid=USER/PWD
buffer=
tables=table_namepartition_name
file=Eexp_paraxxxdmp
log=Eexp_paraxxxlog
()技巧删除表中一个字段
alter table table_name set unused column column_name
()加一个字段
alter table table_name add column_name number()
六总结
分区表是将大表的数据分成称为分区的许多小的子集i提供四种分区方法列表分区范围分区哈希分区和混合分区
范围分区是根椐分区键的不同取值范围来划分子集的关键字RANGE VALUES LESS THAN
列表分区是根椐分区键的一些离散的取值来划分子集的关键字LIST VALUES
哈希分区是应用哈希算法将分区键对应到某个子集中去关键字HASH PARTITIONS
混合分区只能有两层第一层是范围分区第二层可以是列表分区或者哈希分区
范围分区和列表分区中如果插入记录的分区键没有对应的容纳分区会产生ORA
update操作如果会使记录从一个分区迁移到另一个分区且分区表的ROW MOVEMENT属性是DISABLE会产ORA
分区表上的索引有两大类普通的二叉树索引分区索引下面讲到的都是分区索引
按索引分区和表分区间的对应关系可以分为局部索引和全局索引
局部索引的索引分区和表分区间是一一对应的全局索引则相反
局部索引的分区方法可以用上面提到四种的任何一种全局索引的分区方法只有范围分区(而且最高的分区必须用MAXVALUE来定义)
ORACLE自动维护局部索引的分区当表分区被合并分裂或删除时关联的索引分区也会被合并分裂或删除对分区表执行管理操作时会使其上的全局索引失效
建在分区表的位图索引必须是局部分区索引
ORACLE推荐尽可能地使用局部索引
按索引栏位和分区键间的关系分为前缀索引和非前缀索引
前缀索引最前面的栏位是分区键栏位非前缀索引相反
在这两种分类方法的四种组合中只有三种有效(局部前缀索引局部非前缀索引全局前缀索引)不存在全局非前缀索引
分区表给CBO带来很多选项如分区排除并行分区连接等(责任编辑卢兆林)