首页 > 解决方案 > 我的查询需要很长时间才能完成查找列值差异为另一列最大组的行对

问题描述

说,我有一张这样的桌子:

在此处输入图像描述

我想找到每个会话的性能差异最大的中心对,如下所示:

在此处输入图像描述

我有以下查询,

select 
    t1.session,
    t1.center center1,
    t2.center center2,
    t1.performance - t2.performance performance
from mytable t1
inner join mytable t2 on t1.session = t2.session
where t1.performance - t2.performance = (
    select max(t11.performance - t22.performance)
    from mytable t11
    inner join mytable t22 on t11.session = t22.session
    where t11.session = t1.session
)

它可以工作,但需要很长时间,20 列和 200 行的表需要几分钟。如何修改查询以更快地实现相同的输出?

标签: javasqlh2

解决方案


select 
        t1.session,
        t1.center center1,
        t2.center center2,
        t1.performance - t2.performance performance
    from mytable t1
    inner join mytable t2 
       on t1.session = t2.session
    WHERE t1.performance = (SELECT MAX(performance) 
                            FROM mytable t3 WHERE t3.session = t1.session)
      AND t2.performance = (SELECT MIN(performance) 
                            FROM mytable t3 WHERE t3.session = t2.session)

     // Im thinking this will solve the border case when performance is a tie 
     // and difference 0 will return 2 rows

     AND (CASE WHEN t1.performance = t2.performance 
               THEN CASE WHEN t1.center < t2.center
                         THEN 1
                         ELSE 0
                    END
               ELSE 1
          END) = 1

只要你有一个索引performancesession应该没问题。


推荐阅读