(一)索引的概念

索引是一种与表或簇相关的数据库对象,能够为数据的查询提供快捷的存取路径,减少磁盘I/O,提高检索效率。

索引由索引值及记录相应物理地址的ROWID两个部分构成,并按照索引值有序排列,ROWID可以快速定位到数据库表符合条件的记录。可以这样理解,将索引看作是一本书的目录,索引值即为目录的标题,ROWID即为目录的页码。

(二)索引的更新策略

随着标准数据的插入、删除、修改,索引表中的信息会自动更新,具体过程:

l 向表中插入数据时,系统会在索引的叶子节点插入与表对应的索引条目;

l 删除表中的数据时,系统自动删除相关的索引条目,但是空间并没有回收,也不会分配给新的索引条目使用,只有将整个叶子节点删除,空间才会被回收;

l 修改索引表中的数据时,系统会删除索引叶子节点的条目,然后重新分配索引条目

从更新策略可知,索引并不是创建的越多越好。索引在提高查询效率的同时,会降低数据插入、删除、更新的效率。Oracle建议将索引与表分散在不同的表空间中,最好分散在不同的磁盘上,以提高效率。

(三)索引结构

数据库有2种索引结构:平衡树索引结构(B_Tree)和位图索引结构(Bitmap)。

(1) 平衡树索引结构

整个索引结构由根节点、分支节点、叶子节点三部分构成,其中分支节点可以有多层。根节点的信息指向下一层分支节点,最底层的分值节点指向叶子节点,叶子节点保存索引条目信息。索引条目信息由4部分构成:索引基于的列信息(Index entry header)、索引列的长度(key column length)、索引值(key column value)及索引对应的ROWID。B_Tree索引占用空间多,适合索引取值范围广(基数大)、重复率低的应用。

图.平衡树索引结构图

(2)位图索引结构

位图结构也是按平衡树组织的,但是在叶子节点每个索引值对应一个位图而不是一个ROWID,一个位图里面可以包含一个或多个ROWID,位元到ROWID的映射是通过索引中的映射函数实现的。位图索引适合于取值范围小,待索引数据重复率高的列。

图.位图索引结构

(四)创建索引

可以使用create index创建索引:

CREATE [UNIQUE][BITMAP] INDEX [schema.]index_name
ON [schema.]table_name(index_expr[ASC | DESC][,...])
[PCTFREE integer] [PCTUSED integer] [INITRANS integer]
[STORAGE(storage_clause)]
[LOGGING][NOLOGGING]
[ONLINE]
[TABLESPACE tablespace_name]
[NOCOMPRESS | [ COMPRESS integer] ]
[SORT|NOSORT]
[REVERSE]
[NOPARALLEL |[ PARALLEL integer]]

解释:

  • UNIQUE:创建唯一性索引,默认非唯一性
  • BITMAP:创建位图索引,默认B_Tree索引
  • 用于指定索引值的排列顺序,ASC为升序,DESC为降序
  • PCTFREE | PCTUSED | INITRANS设置数据块的使用
  • STORAGE:设置索引的存储方式,若不指定,则继承表空间的存储参数设置
  • LOGGING | NOLOGGING:指明索引创建过程是否写入重做日志文件,默认写入
  • ONLINE:允许在创建索引或重建索引时执行DML(insert/update/delete等需要commit的语句)语句,但不允许执行DDL(create/alter/drop等不需要commit的语句)操作
  • TABLESPACE:指明存储索引的表空间
  • CMPRESS | NOCOMPRESS:是否压缩索引中的重复数据,默认不压缩
  • SORT | NOSORT:在默认情况下,创建索引时会首先对表中数据进行排序,假如我们的数据已经排好序了,我们可以选择NOSORT,加快索引创建的速度;
  • REVERSE:创建反序索引
  • NOPARALLEL | PARALLEL:指明是否允许并行创建索引,默认值为NOPARALLEL
  • 【未完待续。。。】

    [oracle]索引与索引表管理的更多相关文章

    1. Oracle【二维表管理:约束】

      1.简单的表创建和字段类型最简单的方式去创建表(没有添加主键之类的约束条件)[Oracle的字段类型]number:数值类型--整数类型:number(a) 总长度a--小数类型:number(a,b ...

    2. Oracle常用操作——创建表空间、临时表空间、创建表分区、创建索引、锁表处理

      摘要:Oracle数据库的库表常用操作:创建与添加表空间.临时表空间.创建表分区.创建索引.锁表处理 1.表空间 ■  详细查看表空间使用状况,包括总大小,使用空间,使用率,剩余空间 --详细查看表空 ...

    3. 简单了解,使用oracle中的索引,表分区

      索引的分类 如下: 物理分类 逻辑分类 分区或非分区索引 单列或组合索引 B树索引(标准索引) 唯一或非唯一索引 正常或反向键索引 基于函数索引 位图索引   B树索引 b树索引通常也称为标准索引,索 ...

    4. Oracle数据库对象(表空间/同义词/序列/视图/索引)

      数据库对象 Oracle数据库对象: 数据库对象是数据库的组成部分,常常用 CREATE 命令进行创建,可以使用 ALTER 命令修改,用 DROP 执行删除操作. 种类: (1)表空间:所有的数据对 ...

    5. Oracle组合索引与回表

      回表 简单来说就是数据库根据索引找到了指定的记录所在行后,还需要根据rowid再次到数据块里取数据的操作. "回表"一般就是指执行计划里显示的"TABLE ACCESS ...

    6. Oracle索引梳理系列(五)- Oracle索引种类之表簇索引(cluster index)

      版权声明:本文发布于http://www.cnblogs.com/yumiko/,版权由Yumiko_sunny所有,欢迎转载.转载时,请在文章明显位置注明原文链接.若在未经作者同意的情况下,将本文内 ...

    7. Oracle 索引创建、表分区

      --EAF_WORKFLOWSTEP 表创建 CREATE TABLE EAF_WORKFLOWSTEP ( ) NOT NULL PRIMARY KEY USING INDEX TABLESPACE ...

    8. .Net程序员学用Oracle系列(6):表、字段、注释、约束、索引

      <.Net程序员学用Oracle系列:导航目录> 本文大纲 1.表 1.1.创建表 1.2.修改表 & 删除表 2.字段 2.1.添加字段 2.2.修改字段 & 删除字段 ...

    9. oracle查询所有用户表的表名、主键名称、索引、外键等

      1.查找表的所有索引(包括索引名,类型,构成列): select t.*,i.index_type from user_ind_columns t,user_indexes i where t.ind ...

    随机推荐

    1. 深入理解JavaScript系列(31):设计模式之代理模式

      介绍 代理,顾名思义就是帮助别人做事,GoF对代理模式的定义如下: 代理模式(Proxy),为其他对象提供一种代理以控制对这个对象的访问. 代理模式使得代理对象控制具体对象的引用.代理几乎可以是任何对 ...

    2. C#学习笔记8

      1.泛型的约束: (1)接口约束: (2)基类约束,基类约束必须放在第一(假如有多个约束): (3)struct/class约束: (4)多个参数类型的约束,每个类型参数都要用where关键字: (5 ...

    3. java常用API之Calendar类

      Calendar是日历类,该类将所有可能用到的时间信息封装为静态成员变量,方便获取. Calendar为抽象类,由于语言敏感性,Calendar类在创建对象时并非直接创建,而是通过静态方法创建,将语言 ...

    4. jQuery二——属性操作、文档操作、位置属性

      一.jquery的属性操作 jquery对象有它自己的属性和方法. 其中jquery的属性操作模块分为四个部分:html属性操作,dom属性操作,类样式操作和值操作. 1.html属性操作 是对htm ...

    5. web应用和http协议

      一.web应用 Web应用程序是一种可以通过Web访问的应用程序: 程序的最大好处是用户很容易访问应用程序,用户只需要有浏览器即可,不需要再安装其他软件. 应用程序有两种模式C/S.B/S. 1.C/ ...

    6. iDempiere 使用指南 MRP/生产插件 LiberoMFG 源码安装

      Created by 蓝色布鲁斯,QQ32876341,blog http://www.cnblogs.com/zzyan/ iDempiere官方中文wiki主页 http://wiki.idemp ...

    7. RePlugin 插件化-内置加载

      PS:插件化是什么这里就不再说了,从这里开始两种加载方式中的一种(内置加载),该框架是奇虎360开发的,官方给出优点 RePlugin是一套完整的.稳定的.适合全面使用的,占坑类插件化方案.我们&qu ...

    8. 【Mood 20】DailyBuild 4月

      Notification使用详解之三:通过服务更新进度通知&在Activity中监听服务进度 基础总结篇之四:Service完全解析 Notification使用详解之二:可更新进度的通知 A ...

    9. wxpython wx.windows的API

      wx.Window is the base class for all windows and represents any visible object on screen. All control ...

    10. Python学习系列----第五章 模块

      5.1 如何引入模块 在Python中用关键字import来引入某个模块,比如要引用模块math,就可以在文件最开始的地方用import math来引入.在调用math模块中的函数时,必须这样引用: ...