oracle 位图索引的原理

对于普通的B树索引是利用二叉树,这个好理解。请问位图索引是什么样的原理?我好像看过一本书上说是类似横坐标为所有记录的ROWID,纵坐标为索引列的值,然后对于每一个值,在其... 对于普通的B树索引是利用二叉树,这个好理解。请问位图索引是什么样的原理? 我好像看过一本书上说是类似 横坐标为所有记录的ROWID,纵坐标为索引列的值,然后对于每一个值,在其ROWID的位置上标记1 否则标记0 是这样吗?感觉这样会浪费很多空间啊?为什么说位图索引节省空间呢? 展开
 我来答
heyongjia1999
推荐于2018-04-12 · 超过18用户采纳过TA的回答
知道答主
回答量:130
采纳率:0%
帮助的人:60.1万
展开全部
1、语法
create bitmap index index_name on 表名(字段);
2、举个例子你就能明白了:
如有表 test(id,name,address)
数据
(1,张三,大连)
(2,李四,天津)
(3,王五,北京)
(4,赵六,大连)
....

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

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

这样当查询:
select * from 表 where address='大连' or address='北京';
的时候数据库很快就能根据 同行的 1和0 判断出那一条数据符合要求。
Sievers分析仪
2025-01-06 广告
是的。传统上,对于符合要求的内毒素检测,最终用户必须从标准内毒素库存瓶中构建至少一式两份三点标准曲线;必须有重复的阴性控制;每个样品和PPC必须一式两份。有了Sievers Eclipse内毒素检测仪,这些步骤可以通过使用预嵌入的内毒素标准... 点击进入详情页
本回答由Sievers分析仪提供
百度网友07553bf0
2014-01-03 · TA获得超过1986个赞
知道大有可为答主
回答量:2464
采纳率:75%
帮助的人:1879万
展开全部
b-tree索引这样存高度重复的数据








对高度重复的数据 普通索引要反复存,

对于bitmap索引而言:

男 111100
女 000011

男和女的值只要存一次,而后面的位图只占几个字节, 要比btree 索引节约空间
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式