为什么要创建oracle分区表?

一般情况下,如果不分区,则每次查询的对象都是一整张表,如果采用了表分区,那么可以根据具体的分区字段当作条件来避免扫描整张表,减少IO的扫描以提高表的查询速度。

新建(按照日期自动分区)分区表

SQL> create table test_partion(
2 pk_id number(38) generated as identity (start with 1 increment by 1),
3 P_day date,
4 words varchar2(200),
5 constraint pk_test_partition_id primary key (pk_id)
6 )
7 partition by range(P_day)
8 interval (numtodsinterval(1,'day'))
9 (
10 partition part_20170622 values less than (to_date('','yyyyMMdd'))
11 );
Table created
  • 尝试插入数据,之后查看动态分区表的分区个数:
SQL> select * from test_partion ;
PK_ID P_DAY WORDS
--------------------------------------- ----------- ------
SQL> insert into test_partion (p_day,words) values (to_date('','yyyyMMdd'),'');
1 row inserted
SQL> insert into test_partion (p_day,words) values (to_date('','yyyyMMdd'),'');
1 row inserted
SQL> insert into test_partion (p_day,words) values (to_date('','yyyyMMdd'),'');
1 row inserted
SQL> insert into test_partion (p_day,words) values (to_date('','yyyyMMdd'),'');
1 row inserted
SQL> insert into test_partion (p_day,words) values (to_date('','yyyyMMdd'),'');
1 row inserted
SQL> insert into test_partion (p_day,words) values (to_date('','yyyyMMdd'),'');
1 row inserted
SQL> insert into test_partion (p_day,words) values (to_date('','yyyyMMdd'),'');
1 row inserted
SQL> insert into test_partion (p_day,words) values (to_date('','yyyyMMdd'),'');
1 row inserted
SQL> insert into test_partion (p_day,words) values (to_date('','yyyyMMdd'),'');
1 row inserted
SQL> insert into test_partion (p_day,words) values (to_date('','yyyyMMdd'),'');
1 row inserted
SQL> select table_name,partition_name,high_value from user_tab_partitions where table_name='TEST_PARTION';
TABLE_NAME PARTITION_NAME HIGH_VALUE
--------------- ---------------- --------------------------------------------------------------------------------
TEST_PARTION PART_20170622 TO_DATE(' 2017-06-22 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2252 TO_DATE(' 2017-06-23 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2253 TO_DATE(' 2017-06-24 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2254 TO_DATE(' 2017-06-25 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2255 TO_DATE(' 2017-06-26 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2256 TO_DATE(' 2017-06-27 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2257 TO_DATE(' 2017-06-28 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2258 TO_DATE(' 2017-06-29 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2259 TO_DATE(' 2017-06-30 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
9 rows selected

从上边表中我们基本可以看出,除了分区PART_20170622是我们动态创建的分区外,其他SYS_*分区都是动态创建的。

接下来查看每个分区表的数据分区情况:

SQL> select * from test_partion partition(PART_20170622);
PK_ID P_DAY WORDS
--------------------------------------- ----------- -------- SQL> select * from test_partion partition(SYS_P2252);
PK_ID P_DAY WORDS
--------------------------------------- ----------- --------
1 2017/6/22 00001 SQL> select * from test_partion partition(SYS_P2253);
PK_ID P_DAY WORDS
--------------------------------------- ----------- --------
2 2017/6/23 00002
3 2017/6/23 00003
5 2017/6/23 00005 SQL> select * from test_partion partition(SYS_P2254);
PK_ID P_DAY WORDS
--------------------------------------- ----------- -------
4 2017/6/24 00004 SQL> select * from test_partion partition(SYS_P2255);
PK_ID P_DAY WORDS
--------------------------------------- ----------- -------
6 2017/6/25 00006 SQL> select * from test_partion partition(SYS_P2256);
PK_ID P_DAY WORDS
--------------------------------------- ----------- -------
7 2017/6/26 00006 SQL> select * from test_partion partition(SYS_P2257);
PK_ID P_DAY WORDS
--------------------------------------- ----------- -------
8 2017/6/27 00006 SQL> select * from test_partion partition(SYS_P2258);
PK_ID P_DAY WORDS
--------------------------------------- ----------- -------
9 2017/6/28 00006 SQL> select * from test_partion partition(SYS_P2259);
PK_ID P_DAY WORDS
--------------------------------------- ----------- ------
10 2017/6/29 00006

分区操作:

1)删除某个分区表中的数据

SQL> delete from test_partion partition(SYS_P2259);
1 row deleted SQL> select * from test_partion partition(SYS_P2259);
PK_ID P_DAY WORDS
--------------------------------------- ----------- ------

2)删除某个分区

SQL> alter table test_partion drop partition SYS_P2259;
Table altered

删除分区之后,查看表分区情况。

SQL> select table_name,partition_name,high_value from user_tab_partitions where table_name='TEST_PARTION';
TABLE_NAME PARTITION_NAME HIGH_VALUE
--------------- ---------------- --------------------------------------------------------------------------------
TEST_PARTION PART_20170622 TO_DATE(' 2017-06-22 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2252 TO_DATE(' 2017-06-23 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2253 TO_DATE(' 2017-06-24 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2254 TO_DATE(' 2017-06-25 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2255 TO_DATE(' 2017-06-26 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2256 TO_DATE(' 2017-06-27 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2257 TO_DATE(' 2017-06-28 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2258 TO_DATE(' 2017-06-29 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
8 rows selected

注:drop partition时,该分区内存储的数据也将同时删除,你的本意是希望删除掉指定的分区但保留数据,你应该使用merge partition,执行该语句会导致glocal索引的失效需要重建全局索引

3)合并分区

相邻的分区可以通过命令merge partition合并为一个分区,同时分区中的数据也将会被合并到同一个分区中。

新分区的下边界为原来边界值较低的分区,上边界为原来边界值较高的分区,原先的局部索引相应也会合并,全局索引会失效,需要rebuild。

参考:http://www.cnblogs.com/wangfg/p/5286519.html

SQL> alter table test_partion merge partitions SYS_P2253,SYS_P2254 into partition  SYS_P2253_to_P2254;
Table altered SQL> select table_name,partition_name,high_value from user_tab_partitions where table_name='TEST_PARTION';
TABLE_NAME PARTITION_NAME HIGH_VALUE
-------------------------------------------------------------------------------- -------------------------------------------------------------------------------- --------------------------------------------------------------------------------
TEST_PARTION PART_20170622 TO_DATE(' 2017-06-22 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2252 TO_DATE(' 2017-06-23 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2253_TO_P2254 TO_DATE(' 2017-06-25 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2255 TO_DATE(' 2017-06-26 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2256 TO_DATE(' 2017-06-27 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2257 TO_DATE(' 2017-06-28 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2258 TO_DATE(' 2017-06-29 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
7 rows selected SQL> select * from test_partion partition(SYS_P2253_TO_P2254);
PK_ID P_DAY WORDS
--------------------------------------- ----------- --------------------------------------------------------------------------------
2 2017/6/23 00002
3 2017/6/23 00003
5 2017/6/23 00005
4 2017/6/24 00004 SQL> insert into test_partion (p_day,words) values (to_date('20170623','yyyyMMdd'),'06665');
insert into test_partion (p_day,words) values (to_date('20170623','yyyyMMdd'),'06665')
ORA-01502: 索引 "NETPLAN_ONLINE_APPUSER.PK_TEST_PARTITION_ID" 或这类索引的分区处于不可用状态 SQL> alter index PK_TEST_PARTITION_ID rebuild;
Index altered SQL> insert into test_partion (p_day,words) values (to_date('20170623','yyyyMMdd'),'06665');
1 row inserted SQL> insert into test_partion (p_day,words) values (to_date('20170624','yyyyMMdd'),'06665');
1 row inserted SQL> select * from test_partion partition(SYS_P2253_TO_P2254);
PK_ID P_DAY WORDS
--------------------------------------- ----------- --------------------------------------------------------------------------------
2 2017/6/23 00002
3 2017/6/23 00003
5 2017/6/23 00005
4 2017/6/24 00004
12 2017/6/23 06665
13 2017/6/24 06665
6 rows selected

4)分区重命名

SQL>
SQL> alter table test_partion rename partition SYS_P2253_to_P2254 TO SYS_P2253_to_P2254___;
Table altered SQL> insert into test_partion (p_day,words) values (to_date('','yyyyMMdd'),'');
1 row inserted SQL> select table_name,partition_name,high_value from user_tab_partitions where table_name='TEST_PARTION';
TABLE_NAME PARTITION_NAME HIGH_VALUE
-------------------------------------------------------------------------------- -------------------------------------------------------------------------------- --------------------------------------------------------------------------------
TEST_PARTION PART_20170622 TO_DATE(' 2017-06-22 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2252 TO_DATE(' 2017-06-23 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2253_TO_P2254___ TO_DATE(' 2017-06-25 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2255 TO_DATE(' 2017-06-26 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2256 TO_DATE(' 2017-06-27 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2257 TO_DATE(' 2017-06-28 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
TEST_PARTION SYS_P2258 TO_DATE(' 2017-06-29 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIA
7 rows selected SQL> insert into test_partion (p_day,words) values (to_date('20170624','yyyyMMdd'),'76665');
1 row inserted SQL> select * from test_partion partition(SYS_P2253_TO_P2254___);
PK_ID P_DAY WORDS
--------------------------------------- ----------- --------------------------------------------------------------------------------
2 2017/6/23 00002
3 2017/6/23 00003
5 2017/6/23 00005
4 2017/6/24 00004
12 2017/6/23 06665
13 2017/6/24 06665
14 2017/6/24 76665
15 2017/6/24 76665
8 rows selected

因为这里是动态分区,所以就不介绍怎么添加分区。

Oracle12c:自动分区表的更多相关文章

  1. Oracle12c:创建主分区、子分区,实现自动分区插入效果

    单表自动单个分区字段使用方式,请参考:<Oracle12c:自动分区表> 两个分区字段时,必须一个主分区字段和一个子分区字段构成(以下代码测试是在oracle12.1版本): create ...

  2. ORA-14300: 分区关键字映射到超出允许的最大分区数的分区

    环境为:Oracle Database 11g Enterprise Edition Release 11.2.0.2.0 - 64bit Production 对象表为按天的自动分区表: PARTI ...

  3. VMWARE 虚拟机新增硬盘,格式化分区,并挂载

    VMWARE 虚拟机新增 硬盘 并挂载 一台虚拟机上安装ORACLE12c 需要分一块硬盘挂载数据文件 日志文件 以及归档文件 1. 关闭虚拟机 2. 编辑虚拟机设置 选择[编辑虚拟机设置]并打开,将 ...

  4. Oracle间隔(interval)分区

    (一)什么是间隔分区 间隔分区是Oracle 11.1引入的新功能,通过该功能,可以在输入相应分区的数据时自动创建相应的分区.在没有间隔分区技术之前,DBA通常会创建一个maxvalue分区以避免OR ...

  5. ubuntu server下建立分区表/分区/格式化/自动挂载(转)

    link:http://www.thxopen.com/linux/2014/03/30/Linux_parted.html 流程为:新建分区-->格式化分区-->挂载分区 首先弄明白分区 ...

  6. sqlserver分区表实践:对时间分区表自动进行管理

    项目问题:有一张日志表,插入和查询为主,每天记录数据为200多万,大小为2G-4G之间.一开始开发人员使用delete语句手动删除,保留7天数据,经常造成阻塞和性能瓶颈.但是如果不删除数据随着表越来越 ...

  7. 给虚拟机添加新硬盘并分区,fdisk查看分区,分区,重新读取分区表信息partprobe,格式化,挂载,查看分区挂载信息,自动挂载文件/etc/fstab,/etc/fstab文件错误导致重启崩溃后的修复

    1.虚拟机关机断电 2.添加硬盘 2.开机 3.fdisk -l查看刚才新添加的硬盘 [root@localhost ~]# fdisk -l 磁盘 /dev/sda:21.5 GB, 2147483 ...

  8. Oracle12c中SQL性能优化(SQL TUNING)新特性之自动重优化(automatic reoptimization)

    Oracle12c中的自动重优化 Oracle12c中的自适应查询优化有一系列不同特点组成.像自适应计划(AdaptivePlans)功能可以在运行时修改执行计划,但并不允许计划中连接顺序的改变.自动 ...

  9. oracle 11g 分区表创建(自动按年、月、日分区)

    前言:工作中有一张表一年会增长100多万的数据,量虽然不大,可是表字段多,所以一年下来也会达到 1G,而且只增不改,故考虑使用分区表来提高查询性能,提高维护性. oracle 11g 支持自动分区,不 ...

随机推荐

  1. Vue之七导航守卫

    { path:'/',component:Recommend,beforeEnter: (to, from, next) => { console.log(to); ajax('get','/a ...

  2. JS时间处理由CST格式转成GMT格式时间

    问题描述:js接收java后台的时间数据时,时间格式的CST时间,而js默认的是GMT时间格式,js 需要对这个时间进行处理才能使用,具体处理方法如function dateToGMT(sDate){ ...

  3. Algorithm --> 矩阵链乘法

    动态规划--矩阵链乘法 1.矩阵乘法       Note:只有当矩阵A的列数与矩阵B的行数相等时A×B才有意义.一个m×r的矩阵A左乘一个r×n的矩阵B,会得到一个m×n的矩阵C. #include ...

  4. JQuery代码实现上拉加载(不使用插件)

    <script type="text/javascript"> $(window).scroll(function() { //已经滚动到上面的页面高度 var sl_ ...

  5. 动态控制jQuery easyui datagrid工具栏显示隐藏

    //隐藏第一个按钮 $('div.datagrid-toolbar a').eq(0).hide(); //隐藏第一条分隔线 $('div.datagrid-toolbar div').eq(0).h ...

  6. 第二届强网杯-simplecheck

    这次强网杯第一天做的还凑合,但第二天有事就没时间做了(也是因为太菜做不动),这里就记录一下一道简单re-simplecheck(一血). 0x00 大致思路: 用jadx.gui打开zip可以看到,通 ...

  7. hibernate框架学习笔记10:HQL查询详解

    HQL语句中不可以出现与表有关的内容,而是对象的属性 实体类(注意配置文件): package domain; import java.util.HashSet; import java.util.S ...

  8. 第2次作业:Wechat创作史

    Wechat创作史   比尔盖茨曾经说过一句话:21世纪要么电子商务,要么无商可务. 2.1 介绍产品相关信息 -the information about Wechat 你选择的产品是? 选择微信作 ...

  9. C语言程序设计第三次作业--选择结构(1)

    Deadline: 2017-10-29 22:00 一.学习要点 掌握关系运算符和关系表达式 掌握如何判断两个实数相等 掌握常用数学函数的使用 掌握逻辑运算符和逻辑表达式 理解逻辑运算的短路特性 掌 ...

  10. 20162308 实验二《Java面向对象程序设计》实验报告

    20162308 实验二<Java面向对象程序设计>实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S.O.L.I.D原则 ...