Q1:
//该函数返回结果=66666 该语句执行时间=0.035 秒
select f_get(sysdate) from dual
//SQL 语句 1 的执行时间=3 秒
select T2.XXX from T1 inner join T2 on T1.A = T2.A
where T1.B <= f_get(sysdate) and (T1.C is null or T1.C > f_get(sysdate)))
//SQL 语句 2 的执行时间=0.05 秒(直接代入函数的结果)
select T2.XXX from T1 inner join T2 on T1.A = T2.A
where T1.B <= 66666 and (T1.C is null or T1.C > 66666)
为什么会出现这种情况呢 函数执行很快,代入函数结果也很快,执行 SQL+函数就很慢。。。
Q2: 分组求最大值最高效的写法
感谢大家回复
1
mm163 2020-04-23 08:17:32 +08:00
WHERE 字句执行函数,这样索引失效,全表扫描,逐行计算能不慢吗。
|