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: 分组求最大值最高效的写法
感谢大家回复
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.