1.创建普通表

create table normal_shp(id number,day date,city_number number,note varchar2(100)) tablespace p;

插入10000条记录

insert into normal_shp(id,day,city_number,note) select rownum,to_date(to_char(sysdate-180,'J')+trunc(dbms_random.value(0,180)),'J'),ceil(dbms_random.value(1,7)),rpad('a',100,'a') from dual connect by rownum <=100000;

2.创建范围分区表

create table range_shp(id number,day date,city_number number,note varchar2(100))

partition by range(day)

(

partition p1 values less than (to_date('2019-02-01','YYYY-MM-DD')) tablespace p1,

partition p2 values less than (to_date('2019-03-01','YYYY-MM-DD')) tablespace p2,

partition p3 values less than (to_date('2019-04-01','YYYY-MM-DD')) tablespace p3,

partition p4 values less than (to_date('2019-05-01','YYYY-MM-DD')) tablespace p4,

partition p5 values less than (to_date('2019-06-01','YYYY-MM-DD')) tablespace p5,

partition p6 values less than (to_date('2019-07-01','YYYY-MM-DD')) tablespace p6,

partition p_max values less than (maxvalue) tablespace p

)

;

插入100000条记录

insert into range_shp(id,day,city_number,note)

select rownum,to_date(to_char(sysdate-180,'J')+trunc(dbms_random.value(0,180)),'J'),

ceil(dbms_random.value(1,7)),

rpad('a',100,'a')

from dual

connect by rownum <=100000;

3.性能对比

select * from normal_shp;  --普通表

select * from range_shp;   --范围分区表

普通表

范围分区表

 

在不加任何条件时,进行查询发现,两者的逻辑读数量大致相同,花费大致相同;其中范围分区表的逻辑读和花费甚至略高于范围分区表。这是因为分区数量较多,oracle需要管理的段更多(见下图),在进行操作时会引发大量内部的递归调用(recursive calls),因而小表不建议建分区。

对指定时间进行查询:

select * from normal_shp where day=to_date(‘2019-04-01’,’YYYY-MM-DD’);

select * from range_shp where day=to_date(‘2019-04-01’,’YYYY-MM-DD’);

普通表

范围分区表

   

由上图可知,在对指定时间做查询时,对时间做范围分区表的查询更加高效,逻辑读从1853降到了341,花费也更加低。由执行计划仔细观察得,pstart和pstop均为4,代表范围分区表进行查询时,只对于第4个分区进行了全表扫描。

4.创建列表分区表

create table list_shp(id number,day date,city_number number,note varchar2(100))

partition by list(city_number)

(

partition p1 values (1) tablespace p1,

partition p2 values (2) tablespace p2,

partition p3 values (3) tablespace p3,

partition p4 values (4) tablespace p4,

partition p5 values (5) tablespace p5,

partition p6 values (6) tablespace p6,

partition p_other values (default) tablespace p

)

;

5.创建hash分区表

create table hash_shp(id number,day date,city_number number,note varchar2(100))

partition by hash(day)

partitions 6

store in (p1,p2,p3,p4,p5,p6)

;

注:如果表空间数量大于分区数量,则会采用前几个;如果表空间数量小于分区数量,表空间按序循环使用。散列分区的个数尽量使用偶数个。

或者:

-- Create table

create table SYS.HASH_SHP

(

id          NUMBER,

day         DATE,

city_number NUMBER,

note        VARCHAR2(100)

)

partition by hash (DAY)

(

partition SYS_P41 tablespace P1,

partition SYS_P42 tablespace P2,

partition SYS_P43 tablespace P3,

partition SYS_P44 tablespace P4,

partition SYS_P45 tablespace P5,

partition SYS_P46 tablespace P6

);

6.创建组合分区表

常用的:范围-列表分区

create table range_list_shp(id number,day date,city_number number,note varchar2(100))

partition by range(day)

subpartition by list(city_number)

subpartition template

(

subpartition p1 values (1) tablespace p1,

subpartition p2 values (2) tablespace p2,

subpartition p3 values (3) tablespace p3,

subpartition p4 values (4) tablespace p4,

subpartition p5 values (5) tablespace p5,

subpartition p6 values (6) tablespace p6,

subpartition p_other values (default) tablespace p)

(

partition p1 values less than (to_date('2019-02-01','YYYY-MM-DD')) tablespace p1,

partition p2 values less than (to_date('2019-03-01','YYYY-MM-DD')) tablespace p2,

partition p3 values less than (to_date('2019-04-01','YYYY-MM-DD')) tablespace p3,

partition p4 values less than (to_date('2019-05-01','YYYY-MM-DD')) tablespace p4,

partition p5 values less than (to_date('2019-06-01','YYYY-MM-DD')) tablespace p5,

partition p6 values less than (to_date('2019-07-01','YYYY-MM-DD')) tablespace p6,

partition p_max values less than (maxvalue) tablespace p

)

;

7.分区数据交换

分区表的某个分区与普通表进行分区数据交换

alter table range_shp exchange partition p1 with table normal_shp1;

alter table range_list_shp subpartition p1_p1 with table normal_shp1;

(普通表的表结构要和分区一致)

8.分区表的管理

(1)清理分区

alter table range_shp truncate partition p1;

alter table range_list_shp truncate subpartition p1_p1;

(2) 增加表分区

当分区表存在默认条件分区,range中的maxvalue分区,list分区表中的default分区:

①   先删除原默认分区,增加分区后再添加默认分区

    alter table range_shp drop partition p_max; --删除maxvalue分区

    alter table range_shp add partition p_7 values less than (to_date('2019-08-01','YYYY-MM-DD')) tablespace p7; --增加分区

    alter table range_shp add partition p_max values less than (maxvalue) tablespace p; --增加maxvalue分区

    尤其注意,删除默认分区会将数据一并删除,不会分布到其他分区!!!

    ②   使用拆分分区split的方式进行增加

    在目标分区拆分后,被拆分的分区会按照拆分规则将数据重新分布

    alter table list_shp split partition p_other values(7) into (partition p_7  tablespace p7,partition p_other);

    alter table range_shp split partition p_max at(to_date('2019-08-01','YYYY-MM-DD')) into (partition p_7  tablespace p6,partition p_other);

    对于不存在默认条件分区的分区表,直接增加即可;

(3)合并表分区

   对于列表分区,合并的分区无要求;

   对于范围分区,合并的分区需相邻;

   对于散列分区,无法合并

  语法:alter table range_shp merge partitions p1,p2 into partition p0;

(4)收缩分区

  只能在散列分区或者组合分区的hash子分区上进行使用

  alter table hash_shp coalesce partition;

9.分区表索引的维护

全局索引:create index index1 on list_shp(day);

局部索引:create index index2 on range_shp(day) local;

N/A表示局部索引

截断一个分区会将全局索引失效,而局部索引不会失效

加参数可以避免全局索引失效:update global indexes;

Alter table range_shp truncate p1 update global indexes;

oracle分区表原理学习的更多相关文章

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

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

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

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

  3. oracle 分区表和分区索引

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

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

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

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

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

  6. ORACLE工作原理小结

    ORACLE工作原理1-连接 我们从一个用户请求开始讲,ORACLE的完整的工作机制是怎样的,首先一个用户进程发出一个连接请求,如果使用的是主机命名或者是本地服务命中的主机名使用的是机器名(非IP地址 ...

  7. IIS原理学习

    IIS 原理学习 首先声明以下内容是我在网上搜索后整理的,在此只是进行记录,以备往后查阅只用. IIS 5.x介绍 IIS 5.x一个显著的特征就是Web Server和真正的ASP.NET Appl ...

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

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

  9. Oracle教程之学习笔记

    Oracle教程之学习笔记... ----------------------------------- Oracle教程:---学习笔记: ============================= ...

随机推荐

  1. 使用appium+python做UI自动化的demo

    使用appium+python做UI自动化的demo 案例使用的知乎app,下载最新的知乎apk,存在了电脑上,只需要配置本机上app目录,不需要再配置appPackage和appActivity # ...

  2. Linux环境下levelDB源码编译与安装

    1.下载源码并编译 git clone https://github.com/google/leveldb.git cd leveldb //编译源码的时候需要安装cmake,并且版本需要大于3.9, ...

  3. 简记乘法逆元(费马小定理+扩展Euclid)

    乘法逆元 什么是乘法逆元? 若整数 \(b,m\) 互质,并且\(b|a\) ,则存在一个整数\(x\) ,使得 \(\frac{a}{b}\equiv ax\mod m\) . 称\(x\) 是\( ...

  4. 八十年代的经典 NFS和AFS

    NFS:(C/S模式) 大体架构: 1985年Sun公司基于UDP开发了网络共享文件系统(Network FileSystem) NFS由一系列NFS命令和进程组成的客户机/服务器模式,在第三版中加入 ...

  5. PHP 之实现按日期进行分组、分页

    一.效果图 二.原始数据 array(6) { [0]=> array(8) { ["id"]=> string(1) "6" ["use ...

  6. Eclipse生成EXE文件(可视化Login/读取文件)

    Java Swing实现文件的简单读取 WindowBuilder的安装与使用 如何采用java设置一个登陆界面 package jp.services.slink2.batch.so2or; imp ...

  7. pwn学习日记Day6 基础知识积累

    知识杂项 ELF:在计算机科学中,是一种用于二进制文件.可执行文件.目标代码.共享库和核心转储格式文件. char fgets(char buf, int bufsize, FILE stream); ...

  8. shell cat 用法

    cat命令的用途是连接文件或标准输入并打印. 1.命令格式:cat [选项] [文件]... 2.命令功能:cat主要有三大功能:1.一次显示整个文件:cat filename   --常用来显示文件 ...

  9. MySQL中tinytext、text、mediumtext和longtext等各个类型详解

    转: MySQL中tinytext.text.mediumtext和longtext等各个类型详解 2018年06月13日 08:55:24 youcijibi 阅读数 26900更多 个人分类: 每 ...

  10. (翻译) closures-are-not-complicated

    总计:读完这篇文章需要20分钟   这篇文章讲解了闭包的一些内容,作者是拿ES5规范中的一些名词来讲的. 所以可能和博客上一篇文章中提到的binding object, (lexical enviro ...