Oracle 创建索引的基本规则总结

原创 2013年12月04日 23:11:53

1.  选择索引字段的原则:

  • 在WHERE子句中最频繁使用的字段 
  •  联接语句中的联接字段
  • 选择高选择性的字段(如果很少的字段拥有相同值,即有很多独特值,则选择性很好)
  • Oracle在UNIQUE和主键字段上自动建立索引
  • 在选择性很差的字段上建索引只有在这个字段的值分布非常倾斜的情况下才有益(在这种情况下,某一,两个字段值比其它字段值少出现很多)
  • 不要在很少独特值的字段上建B-TREE索引,在这种情况下,你可以考虑在这些字段上建位图索引.在联机事务处理环境下,并发性非常高,索引经常被修改,所以不应该建位图索引
  • 不要在经常被修改的字段上建索引.当有UPDATE,DELETE,INSETT操作时,ORACLE除了要更新表的数据外,同时也要更新索引,而且就象更新数据一样,或产生还原和重做条目
  • 不要在有用到函数的字段上建索引,ORACLE在这种情况,优化器不会用到索引,除非你建立函数索引
  • 可以考虑在外键字段上建索引,这些索引允许当在主表上UPDATE,DELETE操作时,不需要共享子表的锁,这非常适用于在父表和子表上有很多并发的INSERT,UPDATE和DELETE操作的情况
  • 当建立索引后,请比较一下索引后所获得的查询性能的提高和UPDATE,DELETE,INSERT操作性能上的损失,比较得失后,再最后决定是否需建立这个索引 

    2.  选择建立复合索引

     复合索引的优点:

    • 改善选择性:复合索引比单个字段的索引更具选择性 
    •  减少I/O:如果要查询的字段刚好全部包含在复合索引的字段里,则ORACLE只须访问索引,无须访问表

    什么情况下优化器会用到复合索引呢?

           (a) 当SQL语句的WHERE子句中有用到复合索引的领导字段时,ORACLE优化器会考虑用到复合索引来访问.

           (b) 当某几个字段在SQL语句的WHERE子句中经常通过AND操作符联合在一起使用作为过滤谓词,并且这几个字段合在一起时选择性比各自单个字段的选择性要更好时,可

           能考虑用这几个字段来建立复合索引.

           (c) 当有几个查询语句都是查询同样的几个字段值时,则可以考虑在这几个字段上建立复合索引.

    复合索引字段排序的原则:

    • 确保在WHERE子句中使用到的字段是复合索引的领导字段 
    •  如果某个字段在WHERE子句中最频繁使用,则在建立复合索引时,考虑把这个字段排在第一位(在CREATE INDEX语句中) 
    •  如果所有的字段在WHERE子句中使用频率相同,则将最具选择性的字段排在最前面,将最不具选择性的字段排在最后面 
    •  如果所有的字段在WHERE子句中使用频率相同,如果数据在物理上是按某一个字段排序的,则考虑将这个字段放在复合索引的第一位

    二、位图索引

    什么情况下位图索引能够改善查询的性能呢?

    • WHERE子句包含多个谓词于中低基数的字段 
    •  单个的谓词在这些中低基数的字段上选取大量的行 
    •  已经有位图索引创建于某些或全部的这些中低基数的字段上
    • 被查询的表包含很多行
    • 可以在单一个表上建立多个位图索引,因此,位图索引能够改善包含冗长WHERE子句的复杂查询的性能,在合计查询和星形模型的联接查询语句中,位图索引也可以提供比较优良的性能

    位图索引与B-TREE索引的比较

    • 位图索引更节省存储空间
    • 位图索引比较适用于数据仓库环境,但不适于联机事务处理环境.在数据仓库环境,数据维护通常上通过批量INSERT和批量UPDATE来完成的,所以索引的维护被延迟直到DML操作结束.举例:当你批量插入1000行数据时,这些插入的行被放置到排序缓存中(SORT BUFFER),然后批处理更新这1000个索引条目,所以,每一个位图段在每一个DML操作中只需更新一次,即使在那个位图段里有多行被更新
    • 一个键值的压缩位图是由一个或多个位图段所组成,每一个位图段大约相当于半个BLOCK SIZE那么大,锁的最小粒度是一个位图段,在联机事务处理环境,如果多个事务执行同时的更新(即并发的更新),使用位图索引就会影响UPDATE,INSERT,DELETE性能了
    • 一个B-TREE索引的条目只包含一个ROWID,因此,当一个索引条目被锁定,即一行被锁定.但是对于位图索引, 一个索引条目潜在地有可能包含一段ROWID(即某一个范围内的ROWID,有多个ROWID),当一个位图索引条目被锁定时,则这个条目包含的那一段ROWID都被锁定,从而影响并发性.当一个位图段内的ROWID的数量越多时,并发性就越差.虽然如此,对于BULK INSERT,UPDATE和DELETE,位图索引的性能还是比B-TREE索引要好

相关文章推荐

Oracle 创建索引的基本规则总结

一、B-Tree索引 1.  选择索引字段的原则: 在WHERE子句中最频繁使用的字段   联接语句中的联接字段 选择高选择性的字段(如果很少的字段拥有相同值,即有很多独特值,则选择性很好) ...
  • nvhaixx
  • nvhaixx
  • 2011年12月22日 14:06
  • 401

Oracle创建索引的基本规则

原帖地址:http://www.2cto.com/database/201305/211767.html 最近拜读的一篇文章。 Oracle创建索引的基本规则   一、B-Tree索引 1....
  • knuuy
  • knuuy
  • 2015年08月15日 22:47
  • 700

Oracle创建索引的基本规则

Oracle创建索引的基本规则   一、B-Tree索引   1. 选择索引字段的原则:   在WHERE子句中最频繁使用的字段   联接语句中的联接字段   选择高选择...

Oracle 创建索引的基本规则总结 [日期:2011-08-02] 来源:Linux社区 作者:leishifei [字体:大 中 小] 一、B-Tree索引 1. 选择索引字段的原则:

Oracle 创建索引的基本规则总结       一、B-Tree索引 1.  选择索引字段的原则: 在WHERE子句中最频...

’;oracle表,视图,索引,序列,同义词等基本操作总结(作者:西西)

对于oracle初学时有些不知怎样入门,后来入门后觉得蛮有意思。小伙不扯别的了,以下是对oracle基本操作总结: 1)以下代码全部经过验证,包括部分截图,运行无误。 2)是对核心语句基本...

Oracle索引的使用规则

首先,我们要确定数据库运行在何种优化模式下,相应的参数是:optimizer_mode。可在svrmgrl中运行“show parameter optimizer_mode"来查看。ORACLE V7...

Oracle建立索引的规则

在Oracle数据库中,创建索引虽然比较简单。但是要合理的创建索引则比较困难了。笔者认为,在创建索引时要做到三个适当,即在适当的表上、适当的列上创建适当数量的索引。虽然这可以通过一句话来概括优化的索引...

Oracle索引使用规则

首先,我们要确定数据库运行在何种优化模式下,相应的参数是:optimizer_mode。可在svrmgrl中运行“show parameter optimizer_mode"来查看。ORACLE ...

Oracle索引优化规则

索引优化规则: 1. like件中不要以通配符(WILDCARD)开始,否则索引将不被采用. 例:SELECT LODGING FROM LODGING WHERE MANAGER LIKE ‘...
  • ytfy12
  • ytfy12
  • 2013年07月20日 19:55
  • 676

Oracle索引使用规则(一)

首先,我们要确定数据库运行在何种优化模式下,相应的参数是:optimizer_mode。可在svrmgrl中运行“show parameter optimizer_mode"来查看。ORACLE V7...
  • xwnxwn
  • xwnxwn
  • 2011年12月10日 14:40
  • 629
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Oracle 创建索引的基本规则总结
举报原因:
原因补充:

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