oracle存储过程,使用变量时会执行的特别慢
凌空寻宇 2018-08-24 09:36:47 语句为
insert into kwdl
select ... from klt
inner join mwl
on klt.loan_no = mwl.loan_no
and klt.datadate between to_date('2018-07-20','yyyy-mm-dd') and to_date('2018-07-20','yyyy-mm-dd')
and mwl.weightingend = to_date('2999,12,31','yyyy-mm-dd')
where klt.calc_flag = 'y'
and klt.separateness = 'n'
order by klt.loan_no,mwl.weighting_index
其中klt表大概有140W行数据,calc_flag,separateness,datadate均有索引
当单独执行这段语句时,1秒钟就能跑完,插入11138行。
但是如果将上述加粗字段在存储过程中用变量代入,就需要跑5-7分钟。(前后输出时间计算得出)
查看存储计划,当写死时KLT将会走索引,cardinality为3332
但是如果用变量则为full,cardinality为625232
请问这是什么原因?应该如何解决?