gpt4 book ai didi

sql - (MS Access) Row_Number() 超过分区

转载 作者:行者123 更新时间:2023-12-02 00:47:33 25 4
gpt4 key购买 nike

如何在 MS ACCESS 上转换带有过度分区的 row_number() 函数? 我想要实现的是:

来自这张表:

ID  | EntryDate  
10 | 2016-10-10
10 | 2016-12-10
10 | 2016-12-31
10 | 2017-01-31
10 | 2017-03-31
11 | 2015-01-31
11 | 2017-01-31

对于此输出,仅显示每个 ID 的前 3 个最新:

ID  | EntryDate  
10 | 2016-12-31
10 | 2017-01-31
10 | 2017-03-31
11 | 2015-01-31
11 | 2017-01-31

在 SQL Server 上,我可以使用以下代码实现此目的:

select T.[ID],
T.[AptEndDate],
from (
select T.[ID],
T.[AptEndDate],
row_number() over(partition by T.[ID] order by T.[AptEndDate] desc) as rn
from Table1 as T
) as T
where T.rn <= 3;

最佳答案

考虑一个可以在任何 RDBMS 中工作的计数相关子查询。

select T.[ID], T.[EntryDate]
from
(select sub.[ID],
sub.[EntryDate],
(select count(*) from Table1 c
where c.ID = sub.ID
and c.[EntryDate] >= sub.[EntryDate]) as rn
from Table1 as sub
) as T
where T.rn <= 3;

关于sql - (MS Access) Row_Number() 超过分区,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42639018/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com