WEB开发网
开发学院数据库Oracle Oracle编程高手箴言:位图索引的故事 阅读

Oracle编程高手箴言:位图索引的故事

 2009-04-11 13:13:29 来源:WEB开发网   
核心提示: 图片看不清楚?请点击这里查看原图(大图),'800')this.width='800';if(this.height>'600')this.height='600';"border=0>这些Java开发者

图片看不清楚?请点击这里查看原图(大图)。

'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程序。Tom给他们回了一封email,颇有感触地对他们说:

上一页  1 2 3 4  下一页

Tags:Oracle 编程 高手

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接