Oracle中的位图索引及用法

位图索引适用于低基数(low-cardinality)列,所谓低基数列就是指这个列只有很少的可取值。

位图索引的问题:
采用位图索引,一个键指向多行,可能数以百计甚至更多。如果更新一个位图索引键,那么这
个键指向的数百条记录会与你实际更新的那一行一同被有效地锁定。

位图索引的适用场景:
位图索引是针对那些值不经常改变的字段的,在实际应用中,如果某个字段的值需要频繁更新,
那么就不适合在它上面创建位图索引。


1、语法
create bitmap index index_name on 表名(字段);
2、举个例子你就能明白了:
如有表 test(id,name,address)
数据
(1,张三,大连)
(2,李四,天津)
(3,王五,北京)
(4,赵六,大连)
....

类似这样的数据,如果查询的时候用到 【where address='大连'】,因为数据库中有很多这样的数据,所以一般的索引起不到查询加速的作用,而建立位图索引后会产生如下位图效果:
假设有4条数据(就如上所示)

大连 天津  北京
 1    0     0
 0    1     0
 0    0     1
 1    0     0

这样当查询:
select * from 表 where address='大连' or address='北京';
的时候数据库很快就能根据 同行的 1和0 判断出那一条数据符合要求。

你可能感兴趣的:(oracle,数据库)