SQL:获取一列的最大值和对应的其他列

SQL: getting the max value of one column and the corresponding other columns

ID|  tag  |  version
-----+-----+-----
1|  A  |  10
2|  A  |  20
3|  B  |  99
3|  C  |  30
3|  F  |  40

期望的输出:

1 A 10
2 A 20
3 B 99

如何获取每个ID的最大版本以及该版本对应的标签?速度很重要(我有大约 28m 行)所以嵌套的 Select 不会这样做。另外,一个简单的 Group by ID with a max(version) 也不起作用,因为我还需要版本为最大的相应标签。

使用ROW_NUMBER()

SELECT s.id,s.tag,s.version FROM (
    SELECT t.*,
           ROW_NUMBER() OVER(PARTITION BY t.id ORDER BY t.version DESC) as rnk
   FROM YourTable t) s
WHERE s.rnk = 1

试试这个

select id, max(tag) keep(dense_rank first order by VERSION desc) as tag, max(version) as version
from t group by id