㈠ 分区表技术概述
      
      ⑴ Range 分区
      
      ① 例子
         
         create table t
         (...列定义...)
         partition by range (week_num)
         (partition p1 values less than (4)tablespace data0,
           partition p2 values less than (5)tablespace data1,
           ....
          );
          
      ② 适用场景
         
         Range 分区一般比较适合按时间周期进行数据的存储
         
      ③ 优点
         
         用户知道具体数据落在哪个分区
         因此、通过分区可以有效实施各种大批量的数据管理操作
         比如、删除指定时间段的历史数据管理、对指定分区进行备份恢复或导入导出
         
      ④ 缺点
         
         ● 分区的数据可能不均匀
         ● Range分区与记录值相关、实施难度和可维护性相对较差
         
   
      
      ⑵ List分区
         
      ① 例子 
         
         create table t
         (...列定义...)
         partition by list(city)
         (partition p1 values ('北京') tablespace data0,
          partition p2 values ('上海') tablespace data1,
          ....
         );
         
      Range 和 List 的区别在于、前者是连续、而后者是离散
      因此、在优缺点及适用场景方面、大抵相去无几
      这里不赘述了
      
      
      ⑶ HASH 分区
      
      ① 例子
         
         create table t
         (...列的定义..)
         partition by hash (customer_no)
         partition 8 store in 
         (data0,data1);
         
         友情提醒哦:Oracle建议HASH分区数一般是2的幂
         
      ② 适用场景
         
         HASH分区适合于静态数据
         何谓静态数据?
         指此类数据一般永远存储在数据库中、不需要进行历史数据迁移
         例如:用户资料表、账户信息等
         而这类信息的访问大部分通过用户ID或者账号进行
         如果按这些字段进行HASH分区、并建立本地前缀分区索引、访问效率相当高哦
         
      ③ 优点
         
         ● 数据均匀分布
         ● 实施非常简单
         
      ④ 缺点
         

         用户不知道某条记录具体会落在哪个分区
         因此、HASH分区不适合大批量数据管理操作
         例如、历史数据清理、大批量数据导入导出等
         
      
      ⑷ 组合分区
      
      Oracle组合分区某种程度上讲是一种把优点集中的表现
      例如、大多数情况下、第一维按时间字段进行分区、
      这样在分区级适合于进行大批量数据管理操作
      第二维的HASH或List可进一步提高访问性能或者降低实施难度
      
      11g之前只有:Range-HASH 或 Range-List
      
   
   
   ㈡ 分区索引技术概述
      
      生产环境中、有时我们会遇到:
      已经做了分区表了、怎么性能没有提高啊?甚至更慢啊?
      其原因之一或者是没有合理甚至根本没有设计分区索引

先总体认识一下表和索引在分区上的关系:

⑴ 本地前缀分区索引
         
      假设分区表为一个交易流水表t、且按交易日期date进行Range分区
      如果欲创建date字段上的索引、我们可以:
      create index idx_t on t (date) local;
      idx_t 就叫做本地前缀索引
      所谓本地、指索引的分区方法与对应表的分区方法一样
      所谓前缀、指分区字段是索引字段的前缀
      
      优势
      ● 提高查询性能
      ● 当某个分区进行drop 或 merge后、Oracle自动对所对应的索引分区进行相同的操作、
         整个本地前缀分区索引依然有效、无须rebuild
         这样大大保证了表的可用性
    
         
         
      ⑵ 本地非前缀分区索引
      
      假设我们需要在t表的area字段建立分区索引、我们可以:
      create index idx_t_area on t (area) local;
      idx_t_area就叫做本地非前缀分区索引
      
      非前缀要按照索引扫描所有的分区、性能可能更低
      不过、它能够保证按索引访问的可用性
      
      适用场景:
      如果历史数据整理非常频繁、而且不能承受全局分区索引重建的长时间带来的索引不可用
      同时、日常交易性能尚能接受、则建议设计为本地非前缀分区索引
   
   
      
      ⑶ 全局分区索引
      
      假设我们需要在t表的area字段建立分区索引、我们可以:
      create index idx_t_g_area on t(area)
      global partition by range (area)
      (partition p1 less than ...);
      所谓全局、是指该索引的分区与表的分区无关
      10g以后、Oracle提供2种全局分区索引:
      ● Global Range Partition Index 
      ● Global HASH Partition Index 
      
      缺点:
      主要体现在数据的高可用性方面
      当DROP分区后、全局分区索引则全部INVALID、除非REBULID
      但数据量越大、重建索引的时间越长

本文转自:http://blog.csdn.net/dba_waterbin/article/details/8836104

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分区表及分区索引

    转自:http://database.ctocio.com.cn/tips/286/8104286.shtml 关于分区表和分区索引(About Partitioned Tables and Inde ...

  6. 简单ORACLE分区表、分区索引

    前一段听说CSDN.COM里面很多好东西,同事建议看看合适自己也可以写一写,呵呵,今天第一次开通博客,随便写点东西,就以第一印象分区表简单写第一个吧. ORACLE对于分区表方式其实就是将表分段存储, ...

  7. Oracle 分区表中本地索引和全局索引的适用场景

    背景 分区表创建好了之后,如果需要最大化分区表的性能就需要结合索引的使用,分区表有两种索引:本地索引和全局索引.既然存在着两种的索引类型,相信存在即合理.既然存在就会有存在的原因,也就是在特定的场景中 ...

  8. Oracle分区表删除分区引发错误ORA-01502: 索引或这类索引的分区处于不可用状态

    (一)问题: 最近在做Oracle数据清理,在对分区表进行数据清理时,采用的方法是drop partition,删除的过程中,没有遇到任何问题,大概过了10分钟,开发人员反馈部分分区表上的业务失败.具 ...

  9. Oracle 分区表-Range分区

    原文:http://www.tuicool.com/articles/MzeM7r 一.什么是分区表 Oracle提供了分区技术以支持VLDB(Very Large DataBase).分区表通过对分 ...

随机推荐

  1. FZU-2268 Cutting Game(二进制使用)

     Problem 2268 Cutting Game Accept: 254    Submit: 605Time Limit: 1000 mSec    Memory Limit : 32768 K ...

  2. 网络监控工具ntopng

    网络监控工具ntopng   ntopng是Kali提供的一个网络监控软件,用于显示当前网络的使用情况.它能列出当前使用网络的主机,并且显示每台主机发送和接受的数据包.同时,它提供强大的数据处理功能, ...

  3. Linux下将MySQL服务添加到服务器的系统服务中

    Linux下将MySQL服务添加到服务器的系统服务中 Linux环境下将MySQL服务添加到服务器的系统服务中 1.了解MySQL程序路径 MySQL数据目录: /home/mysql/dataMyS ...

  4. MTD

    内存技术设备(英语:Memory Technology Device,缩写为 MTD),是Linux系统中设备文件系统的一个类别,主要用于快闪存储器的应用,是一种快闪存储器转换层(Flash Tran ...

  5. NFS 服务配置篇

    安装.配置NFS服务 1.NFS简介 NFS(network file system) NFS是一个主机A通过网络,允许其他主机B可以来共享主机A的一个目录文件的一个文件系统 2.需要安装两个包nfs ...

  6. 彻底解决DZ大附件上传问题

    个. 注意:很多人遇到修改php.ini后重应WEB服务后仍然不能生效.这种情况应该先确认一下所改的php.ini是不是当前PHP所使用的.您可以在WEB目录下建立一个php文件,内容很简单就一句话& ...

  7. EM算法和GMM模型推导

  8. pc_lint的用法转

    PC-Lint是一款C/C++软件代码静态分析工具,不仅可以检查一般的语法错误,还可以检查潜在的错误,比如数组访问越界.内存泄漏.使用未初始化变量.使用空指针等.在单元测试前使用PC-Lint来检查代 ...

  9. asp.net使用母版页以及Jquery和prototype要注意的问题

    在母版页中引用了js,css或者其他外部文件之后,子页面就不必再重新引用,否则可能出错 prototype.js和jquery.js冲突的解决方案: <script type="tex ...

  10. EffectiveJava(15)强化对象和域的不可变性

    概念: 不可变类是其实例不能被修改的类,不可变类比可变类更加易于设计 实现和使用.它们不容易出错,而且更加安全. 优点 1.不可变对象只有创建时状态. 2.不可变对象本质上是线程安全的,它们不要求同步 ...