Oracle分区表的使用和管理

标签: oracle 分区表 管理 | 发表时间:2013-08-28 17:17 | 作者:u011715137
出处:http://blog.csdn.net

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)  
)    www.2cto.com  
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)  
);  

 

 

-------------------------------------------------------------------------

版权所有,文章允许转载,但必须以链接方式注明源地址,否则追究法律责任!

 

 

 

作者:u011715137 发表于2013-8-28 17:17:19 原文链接
阅读:21 评论:0 查看评论

相关 [oracle 分区表 管理] 推荐:

Oracle分区表的使用和管理

- - CSDN博客数据库推荐文章
Oracle分区表的使用和管理.          在某些场合会使用非常大的表,比如人口信息统计表. 如果一个表很大,就会降低查询的速度,并增加管理的难度. 一旦发生磁盘损坏,可能整个表的数据就会丢失,恢复比较困难. 根据这一情况,可以创建分区表,把一个大表分成几个区(小段),对数据的操作和管理都可以针对分区进行,这样就可以提高数据库的运行效率.

什么是Oracle的分区表?

- - CSDN博客数据库推荐文章
    假设我们现在正在酝酿经营一家图书馆,最初,我们只有十本书提供给大家来阅读和购买. 对于十本书而言,我们可能只需要一个书架格子将其作为保存这十本书的容器就足够了,因为任何一个人都可以很轻松的扫一眼就可以将这十本书的书名大概记住,并且挑选出合适自己的书籍来看.     但是随着我们书籍越来越多,我们需要更大的容器来保存我们的科教类、IT类、历史类、人文类等等书籍,大家都知道的一个生活常识就是,我们肯定不能够将所有类型的书籍都扔到一个书架容器上摆着,最科学的,就是分区,将不同的书籍放到不同的地方去,这样,假如我们在西安五路口的新华书店,那么就只需要跑到四楼的IT分区,去找相关的IT书籍.

Oracle分区表及分区索引

- - Oracle - 数据库 - ITeye博客
分区表的几种分类:. 1、Range(范围)分区. 是应用范围比较广的表分区方式,它是以列的值的范围来做为分区的划分条件,将记录存放到列值所在的. 比如按照时间划分,2012 年1 季度的数据放到a 分区,12年2 季度的数据放到b分区,. 因此在创建的时候呢,需要你指定基于的列,以及分区的范围值,如果某些记录暂无法预测范围,.

Oracle索引管理

- - CSDN博客数据库推荐文章
     语法:create index 索引名称 on 表名称(列名称1,列名称2,.......) tablespace 表空间名称;.     例子:create index  ind_enno on test01(enno) tablespace system;.     创建唯一索引:create unique index 索引名称 on 表名称(列名称1,列名称2,......) tablespace 表空间名称.

Oracle数据库资源管理

- - 技术改变世界 创新驱动中国 - 《程序员》官网
一般来说,Oracle数据库都属于中大型的系统,这类系统的用户会话(Session),小则一两百,多则上千,这些用户会话要求Oracle数据库执行的任何指令都需要耗费系统资源,而系统资源毕竟是宝贵且有限的,一旦突然涌进大量的用户会话,对于有限的资源可能会略显不足. 但这些会话必定有轻重缓急之分,对于重要且紧急的用户会话需求理当获得多一点的系统资源,对于一些不重要或不紧急的用户会话,则可以使用较少的系统资源慢慢处理.

Oracle 管理之 Linux 网络基础

- - CSDN博客数据库推荐文章
1、TCP/IP 网络配置文件. TCP/IP 网络配置文件. IP配置文件:/etc/sysconfig/network-scripts/ifcfg-eth0. 网管配置文件:/etc/sysconfig/network. 域名解析:/etc/host.conf. 主机配置:/etc/hosts.

用SQL语言管理Oracle数据库

- - CSDN博客推荐文章
1,查看数据库的基本属性:. SELECT dbid 数据库编号,name 数据库名称,db_unique_name 全局名称,created 创建时间,log_mode 归档方式,open_mode 访问方式,platform_name 版本类型 FROM v$database;. 2,查看所有数据库对象的类别和大小:.

Oracle数据库的权限、用户、角色管理

- - 服务器运维与网站架构|Linux运维|互联网研究
系统权限:系统规定用户使用数据库的权限. 实体权限:某种权限用户对其它用户的表或视图的存取权限. DBA: 拥有全部特权,是系统最高权限,只有DBA才可以创建数据库结构. RESOURCE:拥有Resource权限的用户只可以创建实体,不可以创建数据库结构. CONNECT:拥有Connect权限的用户只可以登录Oracle,不可以创建实体,不可以创建数据库结构.

(总结)Oracle 11g常用管理命令(用户、表空间、权限)

- - 服务器运维与网站架构|Linux运维|X研究
PS:下面是Oracle 11g最常用的基本管理命令,包括创建用户、表空间,权限分配等. 以下命令本人都验证操作过,加上了本人的小结说明. 从root切换到oracle用户进入:. 进入sqlplus环境,nolog参数表示不登录:. 注:要把Linux下的Oracle配置成服务自启动,请看:. (原创)CentOS Linux下配置Oracle 11gR2为系统服务自动启动.

hiveQL分区表

- - CSDN博客云计算推荐文章
2、加载数据时显示指定分区值. 4、show partitions 可以查看表的分区. 注意:partitioned by 子句中定义的列,数据文件中并不包含这些列值. 5、select 使用分区列查询,hive会对输入做修剪;. 作者:u011984824 发表于2013-11-7 13:25:38 原文链接.