您的位置:首页 > 数据库 > Oracle

oracle各种索引使用场合及建议

2014-11-25 18:02 399 查看
oracle各种索引使用场合及建议

(1)B*Tree索引。

常规索引,多用于oltp系统,快速定位行,应建立于高cardinality列(即列的唯一值除以行数为一个很大的值,存在很少的相同值)。

Create index indexname on
tablename(columnname[columnname...])

(2)反向索引。

B*Tree的衍生产物,应用于特殊场合,在ops环境加序列增加的列上建立,不适合做区域扫描。

Create index indexname on
tablename(columnname[columnname...]) reverse

(3)降序索引。

B*Tree的衍生产物,应用于有降序排列的搜索语句中,索引中储存了降序排列的索引码,提供了快速的降序搜索。

Create index indexname on tablename(columnname
DESC[columnname...])

(4)位图索引。

位图方式管理的索引,适用于OLAP(在线分析)和DSS(决策处理)系统,应建立于低cardinality列,

适合集中读取,不适合插入和修改,提供比B*Tree索引更节省的空间。

Create BITMAP index indexname on
tablename(columnname[columnname...])

在实际应用中,如果某个字段的值需要频繁更新,那么就不适合在它上面创建位图索引。

在位图索引中,如果你更新或插入其中一条数值为N的记录,

那么相应表中数值为N的记录(可能成百上千条)全部被Oracle锁定,

这就意味着其它用户不能同时更新这些数值为N的记录,其它用户必须要等第一个用户提交后,

才能获得锁,更新或插入数据,bitmap index它主要用于决策支持系统或静态数据。

(5)函数索引。

B*Tree的衍生产物,应用于查询语句条件列上包含函数的情况,

索引中储存了经过函数计算的索引码值。可以在不修改应用程序的基础上能提高查询效率。

索引创建策略

1.导入数据后再创建索引

2.不需要为很小的表创建索引

3.对于取值范围很小的字段(比如性别字段)应当建立位图索引

4.限制表中的索引的数目

5.为索引设置合适的PCTFREE值

6.存储索引的表空间最好单独设定

唯一索引和不唯一索引都只是针对B树索引而言.

Oracle最多允许包含32个字段的复合索引

由此估计出一个查询如果使用某个索引会需要读入的数据块块数。

需要读入的数据块越多,则 cost 越大,Oracle 也就越有可能不选择使用 index

三,

能用唯一索引,一定用唯一索引

能加非空,就加非空约束

一定要统计表的信息,索引的信息,柱状图的信息。

联合索引的顺序不同,影响索引的选择,尽量将值少的放在前面

只有做到以上四点,数据库才会正确的选择执行计划。

什么情况下索引不起作用:

1、类型不匹配时

2、条件列包含函数但没有创建函数索引时

3、复合索引中的前导列没有被作为查询条件

4、CBO模式下选择的行数比例过大,优化器采取了全表扫描

5、CBO模式下表很久没分析,表的增长明显,优化器采取了全表扫描
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: