我正在使用DENSE_RANK
为每个组[x]
中的不同[y]
值分配一个序列号。它[rank]
添加新列。
我还想要一个新列,显示每个[x]
内的最大排名[y]
(最高序列号),例如 [highest_rank]
.有没有办法同时获取这个新列,而不必为最大值创建一个单独的表,然后将表连接在一起?
SELECT [x],[y],[rank]
INTO table2
FROM
(
SELECT *, DENSE_RANK() OVER (PARTITION BY [x] ORDER BY [y] ) AS [rank]
FROM table1
) tmp
如果我理解正确,您正在寻找这样的东西:
;WITH cte1 AS (
SELECT *,DENSE_RANK() OVER (PARTITION BY [x] ORDER BY [y] ) AS [rank]
FROM table1
),
cte2 AS (
SELECT [x], [highest_rank]=MAX([rank])
FROM cte1
GROUP BY [x]
)
SELECT cte1.[x],cte1.[y],cte1.[rank],cte2.[highest_rank]
FROM cte1 INNER JOIN cte2 ON cte2.[x]=cte1.[x];