gpt4 book ai didi

sql - 如何在Group By中获取不同的记录

转载 作者:行者123 更新时间:2023-12-02 01:42:20 25 4
gpt4 key购买 nike

我的 SQL Server 表如下所示

 Id     Date                Msg
1 01-01-2015 A
1 02-01-2015 B
2 03-01-2015 C

我想写一个查询得到如下结果

   Id          Date            Msg
1 02-01-2015 B
2 03-01-2015 C

我在努力

 SELECT Id,Max(Date) , Msg
Group By Id, Msg

这也返回第一行。我想要 Msg for Max date for a Particular Id。

有什么建议吗

最佳答案

使用窗口函数

SELECT Id,
Date,
Msg
FROM (SELECT *,
Row_number()OVER (partition BY Id ORDER BY [Date] DESC ) rn
FROM tablename) a
WHERE rn = 1

另一种方法是在子查询中找到每个Id的最大date,然后将结果join到主表.试试这个。

SELECT Id,
Date,
Msg
FROM tablename a
JOIN (SELECT Id,
Max([Date])[Date]
FROM tablename
GROUP BY Id) B
ON a.Id = b.id
AND a.[Date] = b.[Date]

关于sql - 如何在Group By中获取不同的记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27797124/

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