分区表用途

分区表通过对分区列的判断,把分区列不同的记录,放到不同的分区中。分区完全对应用透明。Oracle的分区表可以包括多个分区,每个分区都是一个独立的段(SEGMENT),可以存放到不同的表空间中。查询时可以通过查询表来访问各个分区中的数据,也可以通过在查询时直接指定分区的方法来进行查询。

分区表的优点:

(1)由于将数据分散到各个分区中,减少了数据损坏的可能性;

(2)可以对单独的分区进行备份和恢复;

(3)可以将分区映射到不同的物理磁盘上,来分散IO;

(4)提高可管理性、可用性和性能。

数据量大的表,一般大于2GB;数据有明显的界限划分;对于Long和Long Raw类型列不能使用分区。

分区表类型

一般包括范围分区,散列分区,列表分区、复合分区(范围-散列分区,范围-列表分区)、间隔分区和系统分区等。

范围分区

范围分区根据数据库表中某一字段的值的范围来划分分区。

【语法】

在Create Table语句后增加

PARTITION BY RANGE(column_name)

(

PARTITION part1 VALUES LESS THAN (range1) [TABLESPACE tbs1],

PARTITION part2 VALUES LESS THAN (range2) [TABLESPACE tbs2],

....

PARTITION partN VALUES LESS THAN (MAXVALUE) [TABLESPACE tbsN]

);

【说明】

MAXVALUE:当分区列值都不在设置的范围内时,新增数据将到这个分区中

【示例】

-- 创建表,并设置分区

create table myemp

( empno number(4) primary key,

ename varchar2(10),

hiredate date,

sal   number(7,2),

deptno number(2)

)

partition by range(sal)

(

partition p1 values less than(1000),

partition p2 values less than(2000),

partition p3 values less than(maxvalue)

);

-- 插入数据

insert into myemp(empno,ename,hiredate,sal,deptno)

select empno,ename,hiredate,sal,deptno from emp;

-- 查看工资1000-2000的数据

select * from myemp partition(p2);

-- 删除工资小于1000的数据

delete from myemp partition(p1);

-- 查看数据

select * from myemp;

列表分区

列表分区明确指定了根据某字段的某个具体值进行分区,而不是像范围分区那样根据字段的值范围来划分的。

【语法】

在Create Table语句后增加

PARTITION BY LIST(column_name)

(

PARTITION part1 VALUES (values_list1),

PARTITION part2 VALUES (values_list2),

....

PARTITION partN VALUES (DEFAULT)

);

其中:column_name是以其为基础创建列表分区的列。

part1...partN是分区的名称。

values_list是对应分区的分区键值的列表。

DEFAULT关键字允许存储前面的分区不能存储的记录。

【示例】

-- 创建表,并设置分区

create table myemp2

( empno number(4) primary key,

ename varchar2(10),

hiredate date,

sal   number(7,2),

deptno number(2)

)

partition by list(deptno)

(

partition dept10 values(10),

partition dept20 values(20),

partition dept30 values(30),

partition deptx  values(default)

);

-- 插入数据

insert into myemp2(empno,ename,hiredate,sal,deptno)

select empno,ename,hiredate,sal,deptno from emp;

-- 查看部门20的数据

select * from myemp2 partition(dept20);

-- 删除部门30的数据

delete from myemp2 partition(dept30);

-- 查看数据

select * from myemp2;

建12个月的表空间:(我是建在裸设备上的,你可以根据你自己的情况改变)
create tablespace TBS_USER_201201 datafile '/dev/vgdata1/rlv_user_201201_01' size 8100M;
create tablespace TBS_USER_201202 datafile '/dev/vgdata1/rlv_user_201202_01' size 8100M;
create tablespace TBS_USER_201203 datafile '/dev/vgdata1/rlv_user_201203_01' size 8100M;
create tablespace TBS_USER_201204 datafile '/dev/vgdata1/rlv_user_201204_01' size 8100M;
create tablespace TBS_USER_201205 datafile '/dev/vgdata1/rlv_user_201205_01' size 8100M;
create tablespace TBS_USER_201206 datafile '/dev/vgdata1/rlv_user_201206_01' size 8100M;
create tablespace TBS_USER_201207 datafile '/dev/vgdata1/rlv_user_201207_01' size 8100M;
create tablespace TBS_USER_201208 datafile '/dev/vgdata1/rlv_user_201208_01' size 8100M;
create tablespace TBS_USER_201209 datafile '/dev/vgdata1/rlv_user_201209_01' size 8100M;
create tablespace TBS_USER_201210 datafile '/dev/vgdata1/rlv_user_201210_01' size 8100M;
create tablespace TBS_USER_201211 datafile '/dev/vgdata1/rlv_user_201211_01' size 8100M;
create tablespace TBS_USER_201212 datafile '/dev/vgdata1/rlv_user_201212_01' size 8100M;
创建一张分区表:(一张测试表)
create table T_NM_ADMIN_CENTER  (
   ID                   VARCHAR2(32)                    not null,
   CODE                 varchar2(6)                     not null,
   NAME                 varchar2(50)                    not null,
   ADDRESS              varchar2(80),
   POSTALCODE           varchar2(8),
   PRINCIPAL            varchar2(50),
   LINKMAN              varchar2(50),
   PHONE                varchar2(16),
   URL                  varchar2(50),
   EMAIL                varchar2(60),
   IS_ONLINE            CHAR(1),
   DATA_DATE            DATE,
   SUBMIT_DATE          DATE                           default SYSDATE,
   MODIFY_TIME          DATE
)
partition by range (DATA_DATE)
(
  partition P_201201 values less than (to_date('2012-02-01','YYYY-MM-DD')) tablespace TBS_USER_201201,
  partition P_201202 values less than (to_date('2012-03-01','YYYY-MM-DD')) tablespace TBS_USER_201202,
  partition P_201203 values less than (to_date('2012-04-01','YYYY-MM-DD')) tablespace TBS_USER_201203,
  partition P_201204 values less than (to_date('2012-05-01','YYYY-MM-DD')) tablespace TBS_USER_201204,
  partition P_201205 values less than (to_date('2012-06-01','YYYY-MM-DD')) tablespace TBS_USER_201205,
  partition P_201206 values less than (to_date('2012-07-01','YYYY-MM-DD')) tablespace TBS_USER_201206,
  partition P_201207 values less than (to_date('2012-08-01','YYYY-MM-DD')) tablespace TBS_USER_201207,
  partition P_201208 values less than (to_date('2012-09-01','YYYY-MM-DD')) tablespace TBS_USER_201208,
  partition P_201209 values less than (to_date('2012-10-01','YYYY-MM-DD')) tablespace TBS_USER_201209,
  partition P_201210 values less than (to_date('2012-11-01','YYYY-MM-DD')) tablespace TBS_USER_201210,
  partition P_201211 values less than (to_date('2012-12-01','YYYY-MM-DD')) tablespace TBS_USER_201211,
  partition P_201212 values less than (to_date('2013-01-01','YYYY-MM-DD')) tablespace TBS_USER_201212
);
 
 
 
 

oracle 分区表的更多相关文章

  1. 谈一下如何设计Oracle 分区表

    在谈设计Oracle分区表之间先区分一下分区表和表空间的个概念: 表空间:表空间是一个或多个数据文件的集合,所有数据对象都存放在指定的表空间中,但主要存放表,故称表空间. 分区表:分区致力于解决支持极 ...

  2. 深入学习Oracle分区表及分区索引

    关于分区表和分区索引(About Partitioned Tables and Indexes)对于10gR2而言,基本上可以分成几类: •       Range(范围)分区 •       Has ...

  3. oracle 分区表和分区索引

    很复杂的样子,自己都没有看完,以备后用 http://hi.baidu.com/jsshm/item/cbfed8491d3863ee1e19bc3e ORACLE分区表.分区索引ORACLE对于分区 ...

  4. 谈一下怎样设计Oracle 分区表

    在谈设计Oracle分区表之间先区分一下分区表和表空间的个概念: 表空间:表空间是一个或多个数据文件的集合,全部数据对象都存放在指定的表空间中,但主要存放表,故称表空间. 分区表:分区致力于解决支持极 ...

  5. ORACLE分区表、分区索引详解

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt160 ORACLE分区表.分区索引ORACLE对于分区表方式其实就是将表分段 ...

  6. 【三思笔记】 全面学习Oracle分区表及分区索引

    [三思笔记]全面学习Oracle分区表及分区索引 2008-04-15 关于分区表和分区索引(About PartitionedTables and Indexes) 对于 10gR2 而言,基本上可 ...

  7. oracle分区表彻底删除的办法,处理删不掉的不规则表名

    Oracle分区表彻底删除的办法当对一个不再使用的分区表进行drop后,查询user_tab_partitions视图发现出现如下不规则的分区表表名:SQL> select distinct t ...

  8. Oracle分区表常见操作

    Oracle分区表常用于业务中大表使用,如历史交易记录表等,提高表记录查询效率.本文主要描述范围分区表的创建.新增以及索引创建. Oracle操作分区表相关信息 显示数据库所有分区表的信息:DBA_P ...

  9. ORACLE分区表操作

    ORACLE分区表的操作应用 摘要:在大量业务数据处理的项目中,可以考虑使用分区表来提高应用系统的性能并方便数据管理,本文详细介绍了分区表的使用. 在大型的企业应用或企业级的数据库应用中,要处理的数据 ...

  10. 关于Oracle分区表的理解

    Oracle分区表首要目的是用于管理数据文件,对数据文件进行划分和管理.但常常会听到通过分区表来提高性能的说法,实际上,分区表结合索引,加上有效的SQL语句,确实可以提高性能.什么是有效的SQL呢,就 ...

随机推荐

  1. eclipse菜单解释及中英对照

    在使用Eclipse作为开发工具的时候,建议使用英文版本的(直接百度从官网下就行,这里不详细描述,如果有问题,咱们私聊).虽然中文版本的对于和我一样对英文是小白的看起来特别爽,但是公司大多是英文版本的 ...

  2. Java虚拟机详解02----JVM内存结构

    主要内容如下: JVM启动流程 JVM基本结构 内存模型 编译和解释运行的概念 一.JVM启动流程: JVM启动时,是由java命令/javaw命令来启动的. 二.JVM基本结构: JVM基本结构图: ...

  3. Unity制作FPS Demo

    等到把这个Unity FPS Demo[僵尸杀手]完成后再详细补充一下,使用Unity制作FPS游戏的经历,今天做个标识.

  4. Unity2D Sprite Packer用法介绍

    想充分利用图片空间? 我们用来做sprite的图片通常会留有很多空白的地方,我们在画完了sprite之后,这些地方很可能就没有什么作用了. 如果想避免这些资源上的浪费,我们可以把各个sprite做成图 ...

  5. NGUI国际化 多语言

    相关组件 NGUI的本地化操作相关的组件 Localization UILocalize Language Selection 主要部分 在需要本地化的UILabel上绑定UILocalize,填写K ...

  6. ASP.NET 里的 JSON操作

    最近项目中需要用到 JSON操作,google了一下 找到了几个比较好的操作方法.... 一 .使用 mircosoft 提供的 .NET Framework 自带的 json操作方法 1. 使用Ja ...

  7. 介绍linux下利用编译bash设置root账号共用的权限审计设置

    在日常运维工作中,公司不同人员(一般是运维人员)共用root账号登录linux服务器进行维护管理,在不健全的账户权限审计制度下,一旦出现问题,就很难找出源头,甚是麻烦!在此,介绍下利用编译bash使不 ...

  8. 异步fifo的设计

    本文首先对异步 FIFO 设计的重点难点进行分析 最后给出详细代码 一.FIFO简单讲解 FIFO的本质是RAM, 先进先出 重要参数:fifo深度(简单来说就是需要存多少个数据)           ...

  9. Linux 守护进程一

    守护进程是一个后台进程,它无需用户输入就能运行,经常是提供某种服务. LInux作为服务器,主要的进程也都是为系统或用户提供后台服务功能. 常见的守护进程有Web服务器.邮件服务器以及数据库服务器等等 ...

  10. 思科简单教程CCNA

    这是CCNA的内容,从PC配置交换机(或者路由器),这里呢我们使用的软件叫pack 这是ciso开发的一款工具,能生动形象的模拟现实生活中组网技术的过程,下面我大概讲一下流程,想更多的了解我会录制一些 ...