如何解决在没有子查询的情况下查找最大 sID
我有一个包含 UniqueID、sDate 和 sID-s 的“sSamples”表,例如:
我需要按最新 sDate 并按 UniqueID 分组的 SID-s。
结果应如下所示:
UniqueID | SID
---------------------
031311579 | 11641325
053600109 | 11641353
066051428 | 11641379
093468114 | 11641350
我尝试了不同的查询版本,但性能很慢。对此的最佳解决方案是什么?
感谢您的回答!
解决方法
您没有发布您的版本(因此我们不会重新发布您已经尝试过的内容)。无论如何,如果您没有尝试过分析函数,那么方法如下(来自第 1 - 5 行的样本数据;您可能想尝试的查询从第 6 行开始):
SQL> with ssamples (uniqueid,sdate,sid) as
2 (select '031311579',to_date('18.01.2021 08:18','dd.mm.yyyy hh24:mi'),11641325 from dual union all
3 select '066051428',to_date('20.01.2021 07:50',11641381 from dual union all
4 select '066051428',to_date('20.01.2021 07:51',11641379 from dual
5 )
6 select uniqueid,sid
7 from (select uniqueid,sid,row_number() over (partition by uniqueid order by sdate desc) rn
8 from ssamples
9 )
10 where rn = 1;
UNIQUEID SID
--------- ----------
031311579 11641325
066051428 11641379
SQL>
,
查看预期的输出,您似乎可以将 max
与 keep
子句一起使用,如下所示
Select uniqueid,max(sid) keep (dense_rank last order by sdate) as sid
From your_table
Group by uniqueid
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。