注册 登录
编程论坛 Oracle论坛

数据量过大,跑批时间太长,怎么优化left join 同一张表两次

小白求指教 发布于 2020-08-25 17:31, 5385 次点击
查询结果需要插入另一张表,插入的数据过亿,能优化么
select
 T1.a
 T1.b
 .
 .
 .
 T2.c AS 2c
 T3.c AS 3c
from a T1
 left join b T2
  on T1.a=T2.a
  and T2.b=1
 left join b T3
  on T1.a=T3.a
  and T3.b=2
 
2 回复
#2
雕龙2022-01-03 11:50
你为什么要join 2次呢
 .
  T2.c AS 2c
  T3.c AS 3c
为了 把c变成2列?如果不用把c变2列 那如下:
from a T1
  left join b T2
   on T1.a=T2.a
   and (T2.b=1 or T2.b=2)


[此贴子已经被作者于2022-1-3 11:57编辑过]

#3
ye191342022-01-26 10:37
回复 楼主 小白求指教

可以给两表的a字段加个索引呀,这样联表时应该会快很多。
但是创建索引会消耗大量资源,会导致数据库死锁,最好在非高峰时段创建。
1