折雨的天空
oracle索引优化之join部分
2016-4-20 我好笨


首先说明一下,文中描述的方法没有什么官方依据,完全来自实践,毕竟我只是一个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三个字段创建一个复合索引。





发表评论:
昵称

邮件地址 (选填)

个人主页 (选填)

内容