在11g有一个新的特点是分区表系统。下面做一个实验:

SQL> select * from v$version;

BANNER

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

Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production

PL/SQL Release 11.2.0.1.0 - Production

CORE    11.2.0.1.0      Production

TNS for Linux: Version 11.2.0.1.0 - Production

NLSRTL Version 11.2.0.1.0 - Production

SQL> drop table S_P_TEST purge;

SQL> CREATE TABLE S_P_TEST

    (

     col1 number,

     name varchar2(100)

    )

    PARTITION BY SYSTEM

    (

      PARTITION p1,

      PARTITION p2,

      PARTITION p3,

      PARTITION p4

   );



--插入时要指明分区

SQL> insert into S_P_TEST select object_id,object_name from dba_objects;

insert into S_P_TEST select object_id,object_name from dba_objects

            *

第 1 行出现错误:

ORA-14701: 对于按“系统”方法进行分区的表, 必须对 DML 使用分区扩展名或绑定变量

SQL> insert into S_P_TEST partition(p1) select object_id,object_name from dba_objects

    where object_type='TABLE';

已创建2115行。

SQL> insert into S_P_TEST partition(p2) select object_id,object_name from dba_objects

    where object_type='INDEX';

已创建2888行。

SQL> commit;

SQL> select count(1) from S_P_TEST;

  COUNT(1)

----------

      5003

SQL> select count(1) from S_P_TEST  partition(p1);

  COUNT(1)

----------

      2115

SQL> select count(1) from S_P_TEST  partition(p2);

  COUNT(1)

----------

      2888

--同样的数据能够插入到不同的分区中,这说明数据和分区没有不论什么关系

SQL> insert into S_P_TEST partition(p3) values(1,'aa');

SQL> insert into S_P_TEST partition(p4) values(1,'aa');

SQL> commit;

SQL> select * from S_P_TEST  partition(p3);

      COL1 NAME

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

         1 aa

SQL> select * from S_P_TEST  partition(p4);



      COL1 NAME

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

         1 aa



--传统的分区裁剪和分区智能关联无效,不能建立本地化的索引

SQL> ALTER TABLE S_P_TEST SPLIT PARTITION p1 at(1000)

     into(partition p3,partition p4);

ALTER TABLE S_P_TEST SPLIT PARTITION p1 at(1000)

            *

第 1 行出现错误:

ORA-14255: 未按范围, 列表, 组合范围或组合列表方法对表进行分区

--假设你知道数据在哪个表里面,做好要制定分区条件

SQL> set autotrace traceonly

SQL> select * from S_P_TEST where col1=1;

运行计划

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

Plan hash value: 2020968526

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

| Id  | Operation            | Name     | Rows  | Bytes | Cost (%CPU)| Time     | Pstart| Pstop |

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

|   0 | SELECT STATEMENT     |          |     2 |   130 |    10   (0)| 00:00:01 |       |       |

|   1 |  PARTITION SYSTEM ALL|          |     2 |   130 |    10   (0)| 00:00:01 |     1 |     4 |

|*  2 |   TABLE ACCESS FULL  | S_P_TEST |     2 |   130 |    10   (0)| 00:00:01 |     1 |     4 |

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

Predicate Information (identified by operation id):

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

   2 - filter("COL1"=1)

Note

-----

   - dynamic sampling used for this statement (level=2)

统计信息

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

          5  recursive calls

          0  db block gets

         70  consistent gets

          0  physical reads

          0  redo size

        414  bytes sent via SQL*Net to client

        338  bytes received via SQL*Net from client

          2  SQL*Net roundtrips to/from client

          0  sorts (memory)

          0  sorts (disk)

          2  rows processed

SQL> select * from S_P_TEST partition(p3) where col1=1;

运行计划

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

Plan hash value: 1626227678

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

| Id  | Operation               | Name     | Rows  | Bytes | Cost (%CPU)| Time     | Pstart| Pstop |

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

|   0 | SELECT STATEMENT        |          |     1 |    65 |     4   (0)| 00:00:01 |       |       |

|   1 |  PARTITION SYSTEM SINGLE|          |     1 |    65 |     4   (0)| 00:00:01 |     3 |     3 |

|*  2 |   TABLE ACCESS FULL     | S_P_TEST |     1 |    65 |     4   (0)| 00:00:01 |     3 |     3 |

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

Predicate Information (identified by operation id):

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

   2 - filter("COL1"=1)

Note

-----

   - dynamic sampling used for this statement (level=2)

统计信息

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

          5  recursive calls

          0  db block gets

         15  consistent gets

          0  physical reads

          0  redo size

        385  bytes sent via SQL*Net to client

        338  bytes received via SQL*Net from client

          2  SQL*Net roundtrips to/from client

          0  sorts (memory)

          0  sorts (disk)

1  rows processed

系统分区表的使用场景我想并不多,假设对传统的分区表数据的特性理解是:1.数据和分区是有联系的; 2.分区就是把非常多的表粘在管理结合起来。

该系统分区表只有第二特征。

版权声明:本文博客原创文章,博客,未经同意,不得转载。

Oracle 11g系统分区表中的新功能的更多相关文章

  1. 先学习Oracle 11g的Automatic Diagnostic Repository新功能

    Oracle 11g之前.当数据库出现故障,通常情况下,第一次需要看alert刊物.什么,看看哪些记录错误,您可以给我们的提示.alert文件名 是alert_<ORACLE_SID>.l ...

  2. SQLSERVER2014中的新功能

    SQLSERVER2014中的新功能 转载自:http://blog.csdn.net/maco_wang/article/details/22701087 博客人物:maco_wang SQLSER ...

  3. Oracle 11G R2 RAC中的scan ip 的用途和基本原理【转】

    Oracle 11G R2 RAC增加了scan ip功能,在11.2之前,client链接数据库的时候要用vip,假如你的cluster有4个节点,那么客户端的tnsnames.ora中就对应有四个 ...

  4. PhotoZoom Classic 7中的新功能

    众所周知PhotoZoom Classic是家庭使用理想的放大图像软件.目前很多用户还在使用PhotoZoom Classic 6,对于PhotoZoom Classic 7还是有点陌生.其实在6代衍 ...

  5. ECMAScript 2016,2017 和 2018 中所有新功能的示例

    很难追踪 JavaScript(ECMAScript)中的新功能. 想找到有用的代码示例更加困难. 因此,在本文中,我将介绍 TC39 已完成 ES2016,ES2017 和 ES2018(最终草案) ...

  6. [转]ECMAScript 2016,2017 和 2018 中所有新功能的示例

    很难追踪 JavaScript(ECMAScript)中的新功能. 想找到有用的代码示例更加困难. 因此,在本文中,我将介绍 TC39 已完成 ES2016,ES2017 和 ES2018(最终草案) ...

  7. 一个新人如何学习在大型系统中添加新功能和Debug

    文章背景: 今年七月份正式入职,公司主营ERP软件,楼主所在的组主要负责二次开发,使用的语言是Java. 什么叫二次开发呢?ERP软件的客户都是企业.而这些企业之间的情况都有所不同,一套标准版本的企业 ...

  8. Oracle 11G R2 RAC中的scan ip 的用途和基本原理

    Oracle 11G R2 RAC增加了scan ip功能,在11.2之前,client链接数据库的时候要用vip,假如你的cluster有4个节点,那么客户端的tnsnames.ora中就对应有四个 ...

  9. Java 17 将要发布,补一下 Java 13 中的新功能

    本文章属于Java 新特性教程 系列,已经收录在 Github.com/niumoo/JavaNotes ,点个赞,不迷路. 自从 Oracle 调整了 Java 的版本发布节奏之后,Java 版本发 ...

随机推荐

  1. stm32四种输入

    1.          上拉输入(GPIO_Mode_IPU)   上拉输入就是信号进入芯片后加了一个上拉电阻,再经过施密特触发器转换成0.1信号,读取此时的引脚电平为高电平:   2.       ...

  2. Android——WebView方式开发web App

    昨天接到个酬劳丰厚的任务.把java新生系统做成webApp,想想蛮简单的.所以当时就装作非常为难的样子答应了. 所谓Web App,用曾经我那个老PM的话来说.就是在壳里面套上页面.这里的壳相当于浏 ...

  3. 洛谷 P3112 后卫马克Guard Mark

    ->题目链接 题解: 贪心+模拟 #include<algorithm> #include<iostream> #include<cstring> #incl ...

  4. Hadoop配置文件 分类: A1_HADOOP 2014-08-19 12:48 1157人阅读 评论(1) 收藏

    部分内容参考:http://www.linuxqq.net/archives/964.html  http://slaytanic.blog.51cto.com/2057708/1100974/ ha ...

  5. 使用Opencv中matchTemplate模板匹配方法跟踪移动目标

    模板匹配是一种在图像中定位目标的方法,通过把输入图像在实际图像上逐像素点滑动,计算特征相似性,以此来判断当前滑块图像所在位置是目标图像的概率. 在Opencv中,模板匹配定义了6种相似性对比方式: C ...

  6. IIS服务器能支持10万并发

    服务器能支持10万并发由于一个项目的访问量越来越大,从原来的几百个,增加到现在50多万个每天,所以阿里的服务器也扛不住了,于是就想办法,查了N多资料,总结了以下方法,才解决这问题,每天一共访问量50多 ...

  7. Java基本数据类型之间赋值与运算归纳

    前言:面对“byte b1=3;byteb2=7;byte b=b1+b2;”报错,而“int i1=3;int i2=7;int i=i1+i2;”不报错,进行了深入探究,从而引申出java基本类型 ...

  8. php面试题11(边看边复习刚刚讲的)(array_multisort($arr1,$arr2); 用$arr1来排序$arr2。)

    php面试题11(边看边复习刚刚讲的)(array_multisort($arr1,$arr2); 用$arr1来排序$arr2.) 一.总结 1.边看边复习刚刚讲的 2.array_multisor ...

  9. [Vue] Use Vue.js Component Computed Properties

    You can add computed properties to a component to calculate a property on the fly. The benefit of th ...

  10. [Angular] Using the platform agnostic Renderer & ElementRef

    ElementRef: ElementRef is a way to access native html element, notice that it only works for Broswer ...