7
這是我想要的,但有沒有更簡單,更優雅的方法?爲每組的第一排添加一個排名
IF OBJECT_ID('TEMPDB..#test') IS NOT NULL DROP TABLE #test;
CREATE TABLE #test
(
userAcc VARCHAR(100),
game VARCHAR(100),
amount INT
);
INSERT INTO #test
values
('jas', 'x', 10),
('jas', 'y', 100),
('jas', 'z', 20),
('sam', 'j', 10),
('sam', 'q', 5);
--initial table sample
SELECT userAcc,
game,
amount
FROM #test;
WITH
X AS
(
SELECT rn = ROW_NUMBER() OVER (PARTITION BY userAcc ORDER BY game),
userAcc,
game,
amount,
rk = RANK() OVER (PARTITION BY userAcc ORDER BY amount DESC)
FROM #test
),
Y AS
(
SELECT RK,userAcc,
game,
targ = rn
FROM X
WHERE rk = 1
)
SELECT X.userAcc,
X.game,
X.amount,
ISNULL(Y.targ,0)
FROM X
LEFT OUTER JOIN Y
ON
X.userAcc = Y.userAcc AND
X.rn = Y.rk
ORDER BY X.userAcc,X.rn;
它返回:
這裏是初始表:
什麼腳本正在做的是:
- 在原始表中添加新列
- 在新列中,爲每個userAcc添加最高金額的遊戲排名。
- 排名是遊戲中用戶遊戲中數量最高的字母位置。所以對於jas而言,他的最高分是y,並且在他的比賽中位列第二。
- 步驟3中找到的排名應該僅針對相應用戶的第一個字母遊戲。
您應該編輯的問題,並提供結果也是如此。 –
@GordonLinoff ....現在會做 – whytheq