V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
sandman511
V2EX  ›  问与答

SQL 执行时间与优化问题

  •  
  •   sandman511 · 2020-04-23 02:12:39 +08:00 · 881 次点击
    这是一个创建于 1705 天前的主题,其中的信息可能已经有所发展或是发生改变。

    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 条回复    2020-04-23 08:17:32 +08:00
    mm163
        1
    mm163  
       2020-04-23 08:17:32 +08:00
    WHERE 字句执行函数,这样索引失效,全表扫描,逐行计算能不慢吗。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5859 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 06:22 · PVG 14:22 · LAX 22:22 · JFK 01:22
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.