索引概述

原创 2012年03月23日 03:11:09

一、创建索引的原则

  检索数据不超过表中数据的10%或15%时,创建索引

  相对较小的表不宜创建索引

  对包含在表连接操作中的列创建索引

  对在where子句中频繁使用的列创建索引

  对包含在order by和group by或者涉及排序的union和distinct等其他操作中的列创建索引

  有长字符组成的列不宜创建索引

  被频繁更改的列不宜创建索引

  对表中选择性高的列创建索引

  在OLTP中,表中索引宜少不宜多;而OLAP中,表中的索引可以多一点

  where子句中经常涉及多列,可以考虑创建组合索引

二、估计索引的大小

  declare

  l_used_bytes number;

  l_allocate_bytes number;

  begin

  dbms_space.create_index_cost(

  ddl =>'create index index_name on schema.table_name(column_name)',

  used_bytes =>l_used_bytes,

  alloc_bytes =>l_allocate_bytes);

  dbms_output.put_line('used_bytes='||l_used_bytes||','||'allocate_bytes='||l_allocate_bytes);

  end;

 三、创建唯一索引

  create unique index index_name on schema.table_name(column_name);

四、创建B-树索引  --适于在选择性高、更改较频繁的列上创建

  create index index_name on schema.table_name(column_name);

五、创建位图索引  --适于在选择性低、更改不频繁的列上创建

  create bitmap index index_name on schema.table_name(column_name);

六、创建反键索引  --适用于列值前面差异小,后面差异大的列。在索引段中索引列的值反向存储。

  create index index_name on schema.table_name(column_name) reverse;

七、创建函数索引  --不能使用分组函数

  create index index_name on schema.table_name(function_name(column_name));

八、创建组合索引  --应该把经常使用的列放在最前面

  create index index_name on schema.table_name(column_name1,column_name2 [,column_name3 [, ...]]);

九、分区索引

  1、全局索引 --索引激列和表的分区键不同;不能使用列表分区对索引进行分区;使用范围分区时,必须包含maxsize分区;全局索引的分区和表的分区没有关联。

    create index index_name on schema.table_name(columa_name)

    global

    partition by 分区方法(column_name)

    (

    partition par_name ..........

    )

  2、本地索引  --索引列和表的分区键不同,索引分区和表的分区一一对应。

    create index index_name on schema.table(column_name)

    local;

十、合并和重建索引  --合并仅合并碎片,重建索引使用原索引数据创建新索引,要求表空间能同时容纳两个索引。重建不仅达到合并碎片的目的,也使索引结构更加紧凑。

  合并:alter index index_name coalesce;

  重建:alter index index_name rebuild;

  联机重建:alter index index_name rebuild online;

十一、监控索引

  1、监控

    alter index index_name monitoring usage;

  2、取消监控  --开始监控之后,经过一段时间,然后取消监控,最后查看索引是否使用

    alter index index_name nomonitoring usage;

  3、查看使用情况

    select * from v$object_usage where index_name='index_name';

 

相关文章推荐

C#中索引器的概述

  • 2014年05月05日 22:58
  • 3KB
  • 下载

SQL Server 支持空间数据(Geometry和Geography)的空间索引概述

SQL Server 2008之后支持了空间数据存储(geometry和Geography),那么我们在使用ArcGIS10.1桌面打开这些数据看到相关索引时会看到如下界面:下面就针对SQL Serv...

Oracle索引概述

Oracle序列有两个作用1、提供主键和唯一键约束:外键约束在父表中定义了,所以在子表中不是必须的,但是出于性能的考虑,通常也在子表中的外键约束列建立索引;2、提高系统的系能:语句中有where子句、...
  • DBAFAN
  • DBAFAN
  • 2011年07月25日 09:55
  • 222

数据库索引简要概述

索引是什么?索引是对数据库表中一列或多列的值进行排序的一种结构,使用索引可快速访问数据库表中的特定信息。索引实现原理数据库索引,是数据库管理系统中一个排序的数据结构,以协助快速查询、更新数据库表中数据...

MySQL技术内幕-InnoDB存储引擎读写笔记(索引概述)

1、InnoDB存储类型表类型     InnoDB存储引擎表类似于Oracle的索引组织表,即使用聚簇索引来组织数据。InnoDB每个表都有一个主键,基于主键的聚簇索引来存放数据(B+树的叶子节点...

数据库调优日记--索引调优概述

我出去给客户调优的时候,发现很多客户对数据库索引有一种误解。他们认为索引我们也知道啊,我也会建。调整下索引对系统性能不好有很好的提升。但实际上,等优化有结果对比发现,就是调整索引,让系统性能,有了5倍...

B+树索引概述

1. B+树索引概述 在上一篇文章中,我们讨论了关于index的几个中重要的课题: A) index是保存在磁盘上的一种数据结构,用于提高查询或是扫描record的速度。 B) 排序索引树通过保...

MongoDB索引概述

数据库索引与书籍的索引类似。有了索引就不需要反正本书,数据库可以直接在索引中查找。在索引中找到条目后就可以直接跳转到目标文件中,这能使查找速度提高几个数量级。复合索引1.建立 db.user.en...

MySQL force Index 强制索引概述

以下的文章主要介绍的是MySQL force Index  强制索引,以及其他的强制操作,其优先操作的具体操作步骤如下:我们以MySQL中常用的hint来进行详细的解析,如果你是经常使用Oracle的...
  • li_star
  • li_star
  • 2015年12月22日 17:06
  • 384

GIS空间索引(1)--概述

空间索引 (spatial index) 为便于空间目标的定位及各种空间数据操作,按要素或目标的位置和形状或空间对象之间的某种空间关系来组织和存储数据的结构。 索引 对一个数据集做“索引”,是为了...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:索引概述
举报原因:
原因补充:

(最多只允许输入30个字)