sql - 选择 MAX 日期加上 ID 值

标签 sql sql-server tsql sql-server-2012

请考虑下表...

DECLARE @tmp TABLE
    (
    ID int,
    userID int,
    testID int,
    someDate datetime
    )

...包含以下值:

INSERT INTO @tmp (ID, userID, testID, someDate) VALUES (1, 1, 50, '2010-10-01')
INSERT INTO @tmp (ID, userID, testID, someDate) VALUES (2, 1, 50, '2010-11-01')
INSERT INTO @tmp (ID, userID, testID, someDate) VALUES (3, 1, 50, '2010-12-01')
INSERT INTO @tmp (ID, userID, testID, someDate) VALUES (4, 2, 20, '2010-10-01')
INSERT INTO @tmp (ID, userID, testID, someDate) VALUES (5, 2, 30, '2010-11-01')
INSERT INTO @tmp (ID, userID, testID, someDate) VALUES (6, 2, 20, '2012-11-01')

我需要检索每个 userID/testID 值组合的最大日期,以及随附的 ID 值。结果应该是:

ID   userID  testID  someDate
-------------------------------
3    1       50      2010-12-01
5    2       30      2010-11-01
6    2       20      2012-11-01

当我尝试以下查询时,结果集变得不正确并且显示了所有行。我不能从 GROUP BY 子句中省略 ID,因为它会导致错误。有人可以帮忙吗?将表连接到自身以获取这些值似乎很啰嗦。

SELECT ID, userID, testID, MAX(someDate)
FROM @tmp
GROUP BY testId,userID,ID;

http://www.sqlfiddle.com/#!6/d41d8/5219

最佳答案

请尝试:

select * from (
    select 
        *, 
        ROW_NUMBER() over (partition by userID, testID order by SomeDate desc) Rnum 
    From @tmp
)x where Rnum=1

关于sql - 选择 MAX 日期加上 ID 值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17424333/

相关文章:

mysql - 如何从同一个表的两列中查询等于一个值

mysql - 获取前 5 行的内容并回显它们

sql-server - SQLXML 是否破坏了 1NF?

sql - 存储过程 - 将消息传递回用户应用程序的最佳方式

python - 如何在 PostgreSQL 中将整数解压缩为 float ?

mysql - INNER JOIN 导致查询执行时间很长

c# - 从 SQL 插入查询中获取新记录主键 ID 以将相同的值插入另一个表?

sql - 仅 MS SQL 更新日期

sql - SQL Server 中的窗口函数

sql-server-2005 - 这里可以使用 Common Table 表达式来提高性能吗?