数据库

位置:IT落伍者 >> 数据库 >> 浏览文章

详细讲解Oracle表分区的相关概念及其优点


发布日期:2019年02月22日
 
详细讲解Oracle表分区的相关概念及其优点

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带来很多选项如分区排除并行分区连接等(责任编辑卢兆林)

上一篇:实现Oracle传输表空间的功能“窍门”

下一篇:简析Oracle Online Redo LogFile