Oracle编程高手箴言,位图索引的story

数据库 Oracle
本文主要向你介绍的是Oracle编程高手中的高手的箴言即位图索引的story,你如果是Oracle编程的疯狂一族的话,以下的文章,你一定不要错过。

我想熟悉Oracle数据库的人,一般对这位Oracle高手中的高手编著的《ExpertOracleDatabaseArchitecture-9iand10gprogrammingTechniquesandSolutions》,有所了解吧!同时我也建议大家有时间的话,翻阅一下这本书,会对你在Oracle数据库的学习有很大的帮助。

如果您有时间和兴趣,强烈建议您阅读这本书。这本书最大的特点是语言生动活泼,说理清楚,几乎每讲解一个原理,作者都给出了具体实例,让人读起来毫不气闷。

另外,Thomas谦逊的态度让我非常佩服,Thomas在Oracle数据库方面工作了16年,并且参与了早期Oracle版本的开发,但他仍然谦虚地说,他每天都能从Oracle文档里学到新的东西。

下面从这本书里摘录了一些精彩片段,供您欣赏,虽然不免有断章取义之嫌。

位图索引(BitmapIndex)的故事

一日,一群Java开发者找到Tom先生,说他们新开发的系统已经上线,但性能及其低下,他们问Tom先生能不能替他们看看问题到底出在什么地方。他们告诉Tom,他们的系统采用JSP+EJB+Oracle编程的典型三层架构,其中EJB中的SQL是由第三方工具产生的。

Tom同志一听到EJB,就知道这个系统是不能采用SQL代码跟踪的方法来进行性能调优了。于是,Tom同志告诉这些心急火燎的Java开发者,你们系统的问题肯定在浏览器到数据库之间,但具体问题出在什么地方,我需要看看你们的数据库。

于是,Tom同志远程连接到他们的测试数据库(注意不是生产数据库),查看了几个动态性能视图(V$LOCK和V$SQL),最后终于发现了问题的所在。Tom同志发现他们的数据库中有一个位图索引(BitmapIndex)最为可疑,这个索引是建立在一个PROCESS_FLAG的字段上,PROCESS_FLAG字段表示该记录是否被处理了,可能值只有两个,一个是未处理(N),一个是已经处理(Y)。

当记录初次插入数据库时,该字段的值为N,但其它进程读取并处理那些未处理的记录(值为N的记录)后,这个字段的值就更新为Y。

Tom就问这些Java开发者,你们为什么要在这个PROCESS_FLAG字段上建立位图索引呢?

其中有一个开发者振振有词的说,这是为了提高查找速度,一旦建立了位图索引,我们的程序就能快速找到那些数值为N的记录,然后处理。随后,他又拿出一本大部头的Oracle数据库参考手册,对Tom同志说,这书上都是这么说的,对那些数值非常少的字段,比如,我们的PROCESS_FLAG字段只有两个值,就应该建立位图索引,这难道有什么问题吗?

Tom同志微微一笑,没有直接回答。只见他打开SQLPlus,连接到他的本地Oracle编程实例,给这群开发者演示了下面及其简单的SQL代码。

 

  1. C:\DocumentsandSettings\carlwu>sqlplusscott/
    tiger@carlSQL*Plus:Release11.1.0.6.0
    -ProductiononWedApr2318:15:342008  
  2. Copyright(c)1982,2007,Oracle.Allrightsreserved.  
  3. Connectedto:  
  4. OracleDatabase11gEnterpriseEditionRelease
    11.1.0.6.0-Production  
  5. WiththePartitioning,OLAP,
    DataMiningandRealApplicationTestingoptions  
  6. SQL>createtablet(processed_flagvarchar2(1));  
  7. Tablecreated.  
  8. SQL>createbitmapindext_idxont(processed_flag);  
  9. Indexcreated.  
  10. SQL>insertintotvalues('N');  
  11. 1rowcreated.  
  12. SQL>    

 

刚才那位振振有词的开发者不服气的说,这有什么,不是很正常吗?接着Tom又打开了一个SQLPlus窗口,并连接到本地数据库,键入下面的SQL语句,奇怪的是这条SQL并不执行,而是一直在等待。下面是这条SQL的一个截图,

  1. '800')this.width='800';if(this.height>'600')this.height='600';"border=0> 

这些Java开发者看到这里,惊讶得目瞪口呆。其中一个开发者犹豫地说,好象这个位图索引只允许一个用户操作,如果其它用户想同时操作这个索引,那他必须等第一个用户的请求处理完成,并且提交之后,才能进行,如果第一个用户不提交,那么他必须一直等待。Tom点头表示赞同,然后给他们作了一番详细的解释:

Oracle数据库的位图索引(BitmapIndex)确实是针对那些数值稀疏(low-cardinality,低基数)的字段,但是还应记住的一点是,它是针对那些值不经常改变的字段的。在实际应用中,如果某个字段的值需要频繁更新,那么就不适合在它上面创建位图索引。

在位图索引中,如果你更新或插入其中一条数值为N的记录,那么相应表中数值为N的记录(可能成百上千条)全部被Oracle编程锁定,这就意味着其它用户不能同时更新这些数值为N的记录,其它用户必须要等第一个用户提交后,才能获得锁,更新或插入数据。

问题找到了,修正就很简单了,Tom建议这些开发者去掉了这个位图索引,然后在PROCESS_FLAG字段上建立一个函数索引,只为那些数值为N的记录建立简单的B树索引就可以了。这些开发者回去后,按照Tom的指点,经过一番测试,终于解决了问题。

但故事并没有到此结束,这些开发者并不满足,他们给Tom写email抱怨道,Oracle数据库真“烂”,连这个简单的位图索引问题都不能处理,你看,Oracle浪费了我们大量的时间和精力调试我们的Java程序。是他们就认定,数据库B真烂。但事实并非如此,这只是因为数据库B的工作方式和原理不同于数据库A而已。

世界上没有哪个数据库是“烂”数据库,关键是我们必须深入了解该数据库的架构和特点,这样才能避免这类问题。如果您理解位图索引的适用条件,您还会说Oracle是一个很“烂“的数据库吗?)

最后,Tom乘机建议他们,如果你们愿意,我可以给你们做一次简单的为期3天的培训。这些Java程序员听从了Tom同志的建议,经过了3天的培训后,他们对Oracle能做的事情表示吃惊,他们纷纷表示,“我真傻,原来Oracle编程不适合建立临时表呀,你看我的程序老是在那里删除和创建临时表。”,“要是我用了物化视图(MateralizedView),我的数据备份代码就异常简单了。”,“我还不知道connectby有这么强大的功能呢!”。

【编辑推荐】

  1. Oracle to_char函数具有强大功能的体现
  2. Oracle数据库LogMiner工具的运用
  3. Oracle 11g调用函数的五种方法简介
  4. Oracle性能调整中的相关要点的介绍
  5. 惠普邮件归档平台运用存储网格技术
责任编辑:佚名 来源: 博客园
相关推荐

2009-04-10 14:38:17

Oracle高手位图索引

2021-08-27 22:07:55

Oracle索引位图

2010-04-07 17:56:49

Oracle位图索引

2009-11-11 09:13:11

Oracle索引扫描

2013-10-31 09:36:43

程序员程序高手

2015-07-28 17:11:00

编程技术提升

2009-11-17 10:20:01

Oracle Spat

2009-11-17 15:59:25

Oracle物化视图

2011-05-30 15:59:47

编程

2010-10-26 17:34:03

Oracle索引

2009-10-29 16:57:05

Oracle传输表空间

2010-10-26 16:33:54

创建Oracle索引

2010-11-16 09:18:39

oracle重建索引

2010-10-27 13:47:50

Oracle索引

2022-03-29 08:18:32

位图算法索引技术

2010-04-07 17:45:22

Oracle位图索引

2009-03-19 15:52:50

Silverlight位图WPF

2010-10-26 17:17:37

创建ORACLE索引

2011-05-20 11:33:06

ORACLE索引约束

2009-11-02 18:56:49

调整Oracle数据库
点赞
收藏

51CTO技术栈公众号