0

我正在尝试从我的数据库中的表中选择不同的(最后更新的)行。我正在尝试获取每个“子部分”的最后更新行。但是我找不到实现这一目标的方法。

该表如下所示:

ID    | Name   |LastUpdated                  | Section    | Sub    |

1     | Name1  | 2013-04-07 16:38:18.837     | 1          | 1      |
2     | Name2  | 2013-04-07 15:38:18.837     | 1          | 2      |
3     | Name3  | 2013-04-07 12:38:18.837     | 1          | 1      |
4     | Name4  | 2013-04-07 13:38:18.837     | 1          | 3      |
5     | Name5  | 2013-04-07 17:38:18.837     | 1          | 3      |

我试图让我的 SQL 语句做的是返回行:

1、2 和 5。

它们对于 Sub 和最新的是不同的。

我试过了:

SELECT DISTINCT Sub, LastUpdated, Name 
FROM TABLE 
WHERE LastUpdated = (SELECT MAX(LastUpdated) FROM TABLE WHERE Section = 1)

它只返回最近更新的行的不同行。这是有道理的。

我已经用谷歌搜索了我正在尝试的内容,并在这里查看了相关帖子。但是没有设法找到一个真正回答我正在尝试的东西。

4

2 回答 2

1

您可以使用row_number()窗口函数为具有相同 Sub 值的行的每个分区分配编号。使用order by LastUpdated desc,第 1 行将是最新行:

select  *
from    (
        select  row_number() over (
                    partition by Sub 
                    order by LastUpdated desc) as rn
        ,       *
        from    YourTable
        ) as SubQueryAlias
where   rn = 1
于 2013-04-07T19:49:51.010 回答
-1

使用 group by 还不够吗?

SELECT DISTINCT MIN(Sub), MAX(LastUpdated), MIN(NAME) FROM TABLE GROUP BY Sub Where Section = 1
于 2013-04-07T19:51:41.983 回答