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三个字段创建一个复合索引。

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

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值