作者:西岑村内徐老爷 | 来源:互联网 | 2023-10-12 08:42
首先说明一下,文中描述的方法没有什么官方依据,完全来自实践,毕竟我只是一个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三个字段创建一个复合索引。
------------正 文 已 结 束, 感 谢 您 的 阅 读 (折雨的天空)--------------------