折雨的天空

博客介绍:本博客当前共有文章【974】篇,总阅读量【5,245,149】次,第一篇博客发表于【2011年04月06日 10时34分】,距今已【5036】天,感谢您的使用!

您的位置:折雨的天空 >其他技术> oracle索引优化之join部分

oracle索引优化之join部分

首先说明一下,文中描述的方法没有什么官方依据,完全来自实践,毕竟我只是一个PHP程序员。


问题描述:



select count(*) as counter from examination_table left join individual_core on examination_table.id=individual_core.uuid where (instr(individual_core.region_path,'0,1')=1) and (examination_table.jkxw='1') and (individual_core.status_flag='1') 

统计数据量,耗时5秒以上。



看SQL DEVELOPER的解释计划,三个条件均不走索引,全部是FULL SCAN。


但是,移除条件:

(instr(individual_core.region_path,'0,1')=1)  and (individual_core.status_flag='1')

耗时瞬间零点几毫秒。 剩下的唯一条件走索引了。 想了很久,没有头绪,单独查询 表individual_core加上移除的条件,仍然是走索引,大概零点五毫秒左右。

网上翻看了半天,也没有什么收获,最后看到一篇文章:

http://use-the-index-luke.com/sql/join/hash-join-partial-objects

关于索引的,不是太明白,也只看了一段,根据其中描述,join on的时候,on的字段是否有索引。 


我这边的情况是:on后面两个字段都有索引,但on和where后面的字段并没有建立复合索引。 

问题就在这里: 我一直想的是,两个表连接的时候,怎么给两个表同时建索引呢,显然是不可能的。 


但是又要让查询走索引,那么这里实践出的一种方法就是: 

在同一个表中,给on后面的字段和where后面的字段,建立复合索引。


比如我这里的就分别给: 1、examination_table表的 id和jkxw两个字段创建一个复合索引。 2、individual_core的uuid,region_path,status_flag三个字段创建一个复合索引。


------------正 文 已 结 束, 感 谢 您 的 阅 读 (折雨的天空)--------------------

转载请注明本文标题和链接:《oracle索引优化之join部分

奖励一下

取消

分享不易,烦请有多多打赏,如您也困难,点击右边关闭即可!

扫码支持
扫码打赏,5元,10元,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

-秒后自动关闭,如已打赏,或者不愿打赏,请点击右上角关闭图标。

发表评论

路人甲 表情
看不清楚?点图切换