B树索引
主键和唯一性约束字段的B树索引,效率几乎和海量数据没有关系。

键值重复率低的字段比较适合使用B树索引。

位图索引
键值重复率高的字段比较适合使用位图索引。
count、and、or、in这些特定的操作更适合位图索引。

DML操作比较多的表不适合使用位图索引。

复合索引
在where条件中必须带驱动列,复合索引才会使用。

键值重复率低(DISTINCT数量多)的字段放在前面。

用实验说明为什么位图索引不适合OLTP,比较适合OLAP。即:DML操作比较多的表不适合使用位图索引。

首先创建测试表:

  1. SQL> create table t1(id int,name varchar(10),value varchar(10));
  2. 表已创建。
  3. SQL> create bitmap index ind_t1_id on t1(id);
  4. 索引已创建。
  5. SQL> insert into t1 values(1,'a','aa');
  6. 已创建 1 行。
  7. SQL> insert into t1 values(1,'b','bb');
  8. 已创建 1 行。
  9. SQL> commit;
  10. 提交完成。
  11. SQL> select * from t1;
  12. ID NAME       VALUE
  13. ---------- ---------- ----------
  14. 1 a          aa
  15. 1 b          bb

session1:

  1. SQL> select distinct sid from v$mystat;
  2. SID
  3. ----------
  4. 140
  5. SQL> update t1 set id = 2 where name = 'a';
  6. 已更新 1 行。

session2:

  1. SQL> select distinct sid from v$mystat;
  2. SID
  3. ----------
  4. 147
  5. SQL> update t1 set id = 2 where name = 'b';

阻塞信息:

  1. SQL> select * from v$lock where sid in(140,147) order by type;
  2. ADDR     KADDR           SID TY        ID1        ID2      LMODE    REQUEST      CTIME      BLOCK
  3. -------- -------- ---------- -- ---------- ---------- ---------- ---------- ---------- ----------
  4. 288F60DC 288F60F4        147 TM      55628          0          3          0        111          0
  5. 288F6030 288F6048        140 TM      55628          0          3          0        270          0
  6. 28945B40 28945B64        147 TX     655404        533          6          0        111          0
  7. 28939F60 28939F84        140 TX     589829        616          6          0        270          1
  8. 294344A8 294344BC        147 TX     589829        616          0          4        111          0
  9. SQL> select sid,status,last_call_et,blocking_session from v$session where sid in(140,147);
  10. SID STATUS   LAST_CALL_ET BLOCKING_SESSION
  11. ---------- -------- ------------ ----------------
  12. 140 INACTIVE          285
  13. 147 ACTIVE            126              140

可以看见140阻塞了147。尽管他们修改的不是同一列。

注意:这里不仅仅是根据name='a'去修改会阻塞其他会话,如果根据value = 'aa'或者name = 'a' and value = 'aa'来修改操作,也是同样会阻塞的!!! 因为都是改的id的值,而Index就是建在id上面的。但是如果不是改id列,而是改name或者value列就不存在阻塞的情况!!!

如果使用B树索引,就不存在阻塞情况了。创建同样的t2表,只是索引不一样

  1. SQL> create table t2 as select * from t1;
  2. 表已创建。
  3. SQL> select * from t2;
  4. ID NAME       VALUE
  5. ---------- ---------- ----------
  6. 2 a          aa
  7. 2 b          bb
  8. SQL> create index ind_t2_id on t2(id);
  9. 索引已创建。

session1:

  1. SQL> select distinct sid from v$mystat;
  2. SID
  3. ----------
  4. 140
  5. SQL> update t2 set id = 1 where name = 'a';
  6. 已更新 1 行。

session2:

  1. SQL> select distinct sid from v$mystat;
  2. SID
  3. ----------
  4. 147
  5. SQL> update t2 set id = 1 where name = 'b';
  6. 已更新 1 行。

可以看见,各自都可以修改,不存在阻塞现象!

B树索引和位图索引的区别!的更多相关文章

  1. [转帖]B树索引、位图索引和散列索引

    B树索引.位图索引和散列索引   https://blog.csdn.net/huashanlunjian/article/details/84460436 索引在数据结构上可以分为三种B树索引.位图 ...

  2. [转帖]B树索引和位图索引的结构介绍

    B树索引和位图索引的结构介绍 http://blog.itpub.net/12679300/viewspace-1174236/ 一  前言:? ROWID:包含键值的行的行ID,(查找块的最快方法, ...

  3. Atitit 索引技术--位图索引

    Atitit 索引技术--位图索引 索引在数据结构上可以分为三种B树索引.位图索引和散列索引 存储原理 编辑 位图索引对数据表的列的每一个键值分别存储为一个位图,Oracle对于不同的版本,不同的操作 ...

  4. Oracle索引梳理系列(四)- Oracle索引种类之位图索引

    版权声明:本文发布于http://www.cnblogs.com/yumiko/,版权由Yumiko_sunny所有,欢迎转载.转载时,请在文章明显位置注明原文链接.若在未经作者同意的情况下,将本文内 ...

  5. Oracle索引——位图索引

    1.语法create bitmap index index_name on 表名(字段);2.举个例子你就能明白了:如有表 test(id,name,address)数据(1,张三,大连)(2,李四, ...

  6. Oracle - 位图索引的适用条件

    位图索引的适用条件 位图索引适合只有几个固定值的列,如性别.婚姻状况.行政区等等,而身份证号这种类型不适合用位图索引. 位图索引适合静态数据,而不适合索引频繁更新的列. 举个例子,有这样一个字段bus ...

  7. oracle的位图索引和函数索引

    1.位图索引 位图索引适用于性别.婚姻状态.行政区等只有几列固定值的类型列,身份证号等就不适合位图索引,位图索引适用于静态数据,频繁更新的字段不适用建立位图索引,因为更新会导致索引块区的变更,还会引起 ...

  8. ( 转 ) 数据库BTree索引、Hash索引、Bitmap位图索引的优缺点

    测试于:MySQL 5.5.25 当前测试的版本是Mysql 5.5.25只有BTree和Hash两种索引类型,默认为BTree.Oracle或其他类型数据库中会有Bitmap索引(位图索引),这里作 ...

  9. Oracle索引之Btree索引

    索引介绍 日常开发中,对于数据的查询如果需要优化,常听说要加个索引.但是为什么加了索引,数据的查询就快了呢?那是不是加了索引就一定会是有效或者有利的呢? Oracle中常见有BTREE索引,位图索引和 ...

随机推荐

  1. Eclipse插件开发 swt ComboBoxCellEditor CCombo 下拉框高度

    效果图:     代码如下 bindingPageTableViewer.setCellModifier(new ICellModifier() { public boolean canModify( ...

  2. [设计模式] 13 责任链模式 Chain of Responsibility

    转    http://blog.csdn.net/wuzhekai1985   http://www.jellythink.com/archives/878 向项目经理提交了休假申请,我的项目经理向 ...

  3. [设计模式] 22 模板方法模式 template

    转http://www.jellythink.com/archives/407 在GOF的<设计模式:可复用面向对象软件的基础>一书中对模板方法模式是这样说的:定义一个操作中的算法骨架,而 ...

  4. 有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。

    先写我的思路,没有用指针的做法.如果你用的是VC,把第六行去掉. #include<stdio.h> #include<stdlib.h> int main() { setvb ...

  5. android2.3 -添加自定义按键:作唤醒功能 .

    最近需要做个唤醒功能,当按键的时候android系统唤醒并点亮屏,在长按键中,系统不能在进入睡眠. 驱动方面: 1:在平台设备文件中添加 一个按键,定义为唤醒源! \arch\arm\mach-s5p ...

  6. jsp bean标签

    jsp中存在一个奇奇怪怪的bean标签. 例如 现在在java包中定义一个类test2 package bean; public class test { private int number; pu ...

  7. POJ 1844

    #include <iostream> #define MAXN 20 using namespace std; int value[MAXN]; int place[MAXN]; ]; ...

  8. eclipse配置mahout

    1.在elcipse上建立一个java project 项目名:mymahout 2.建立libs文件夹,在mahout 0.9的lib文件夹下找到一下java包 其中log4j.properties ...

  9. Oracle 6 - 锁

    Oracle锁没有额外的开销?Oracle的锁是怎么实现的?因为其他数据库,锁都是一种稀有资源和开销. 答:代码级实现?? 没有锁的话,并发更新就会有丢失更新的问题. 悲观锁和乐观锁 悲观锁一般用于有 ...

  10. Oracle 6 - 锁和闩 - 锁类型

    Oracle锁大类 1.DML锁 (SELECT, INSERT, UPDATE, DELETE, MERGE是对数据库加的锁, 可能是行锁,也可能是表锁) 2.DDL锁 (Create, Alter ...