Oracle中分区表的使用
前提:
查询分区:Select *From user_extents WHERE partition_name='分区名';
1)创建表空间
create tablespace HRPM0
datafile '/oradata/misdb/' size 5m autoextend on next 10m maxsize unlimited
2)删除表空间(同时把数据文件也删除)
DROP TABLESPACE data01 INCLUDING CONTENTS AND DATAFILES;
如果不想删除数据文件:
Drop tablespace tablespace_name;
3) 修改表空间大小
alter database datafile '/path/' resize 100M
4)添加数据文件(在建立表空间时,若是约束了表空间的大小,那么一段时间后,这个表空间就会被装满,无法再添加其他对象。则需要给表空间添加数据文件):
Alter tablespace tablespace_name add datafile’'/path/’ size 100M;
4) 备注:
).--. 禁止undo tablespace 自动增长
alter database datafile 'full_path\' autoextend off;
).-- 创建一个新的小空间的undo tablespace
create undo tablespace undotBS2 datafile 'full_path\' size 100m;
).-- 设置新的表空间为系统undo_tablespace
alter system set undo_tablespace=undotBS2;
).-- Drop 旧的表空间
drop tablespace undotbs1 including contents;
).-- 查看所有表空间的情况
select * from dba_tablespaces
5) 查到一个最好用的表:dict
)select * from dict where table_name like '%PART%'
)ALL_TAB_PARTITIONS : 可以查出表所对应的分区内容;
) dab_tab_partitons :与上2);
)dba_ind_partitons: 查询分区的索引;
) 子分区也是一样的(dba_tab_subpartitons,dba_ind_partitons)
一、使用分区的优点:
1 、增强可用性:如果表的某个分区出现故障,表在其他分区的数据仍然可用;
2 、维护方便:如果表的某个分区出现故障,需要修复数据,只修复该分区即可;
3 、均衡I/O:可以把不同的分区映射到磁盘以平衡I/O,改善整个系统性能;
4、改善查询性能:对分区对象的查询可以仅搜索自己关心的分区,提高检索速度。
二、Oracle数据库提供对表或索引的分区方法有几种(收集到四种):
1 、范围分区
2 、列表分区
3 、Hash分区(散列分区)
4 、复合分区
三、详描述分区实例:
1 )下面将以实例的方式分别对这三种分区方法来说明分区表的使用。为了测试方便,我们先建三个表空间。
create tablespace dinya_space01 datafile 'C:\ 表空间\' size 5 M ; create tablespace dinya_space02 datafile 'C:\ 表空间\' SIZE 5 M ; create tablespace dinya_space03 datafile 'C:\ 表空间\' SIZE 5 M ;
select * from user_tablespaces
< 表空间-> 三个>
)范围分区
范围分区就是对数据表中的某个值的范围进行分区,根据某个值的范围,决定将该数据存储在哪个分区上。如根据序号分区,根据业务记录的创建日期进行分区等。
需求描述:有一个物料交易表,表名:material_transactions。该表将来可能有千万级的数据记录数。
Oracle中分区表的使用 来自淘豆网m.daumloan.com转载请标明出处.