索引概述

原创 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';

 

位图索引介绍

位图索引是指使用计算机的最小单位bit来存储列值,并使用它自动生成rowid的一种索引结构。直接将列值转换为位存储不仅在很大程度上节约了存储空间,而且通过各种位运算还可以解决现有索引不能解决的很多问题...
  • minwang593
  • minwang593
  • 2013年10月09日 20:54
  • 387

索引概述和索引分类

索引是一种特殊的文件(InnoDB数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的引用指针。更通俗的说,数据库索引好比是一本书前面的目录,能加快数据库的查询速度。索引是快速搜索的...
  • qq_31617637
  • qq_31617637
  • 2017年05月14日 15:51
  • 133

索引概述和创建索引

索引概述       索引                              使用索引为了提高访问速度       优点               创建索引        如果已有聚集索...
  • kangshihang1998
  • kangshihang1998
  • 2017年02月16日 17:28
  • 306

MySQL 索引原理概述及慢查询优化实战

MySQL凭借着出色的性能、低廉的成本、丰富的资源,已经成为绝大多数互联网公司的首选关系型数据库。虽然性能出色,但所谓“好马配好鞍”,如何能够更好的使用它,已经成为开发工程师的必修课,我们经常会从职位...
  • risingsun001
  • risingsun001
  • 2015年03月18日 11:30
  • 2148

innodb的索引的概述

innnodb的索引分为两种 B+树索引 B+树索引的构造类似于二叉树,根据key value快速找到数据,但是B+树索引中的B并不是代表的binary,而是代表balance,B+树是从平衡树...
  • u012920673
  • u012920673
  • 2017年11月09日 16:19
  • 45

oralce 索引概述

一、索引概述     索引是数据库中一种可选的数据结构,她通常与表或簇相关。用户可以在表的一列或数列上建立索引,以提高在此表上执行 SQL 语句的性能。正确地使用索引能够显著的减少磁盘 I/O。 ...
  • LinusFay
  • LinusFay
  • 2013年07月19日 16:18
  • 799

oracle 索引概述

一. 概念 (1) 类似书的目录结构,可以提高数据检索的速度 (2) 索引直接指向包含所查询值的行的位置,减少磁盘I/O (3) 索引与表在物理上独立,Oracle 自动使用并维护索引,插入、删...
  • u014531707
  • u014531707
  • 2015年09月15日 17:27
  • 187

MonogDB -索引(一)概述

MongoDB索引的使用。
  • Crazy__Programmer
  • Crazy__Programmer
  • 2014年04月09日 09:08
  • 3599

B+树索引概述

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

MongoDB索引概述

数据库索引与书籍的索引类似。有了索引就不需要反正本书,数据库可以直接在索引中查找。在索引中找到条目后就可以直接跳转到目标文件中,这能使查找速度提高几个数量级。复合索引1.建立 db.user.en...
  • qq_18149897
  • qq_18149897
  • 2015年12月26日 18:03
  • 204
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:索引概述
举报原因:
原因补充:

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