前言:五更!五更琉璃!不對!是,五更佩可!
原始數據:
new_hires
reason | other_column1 | other_column2 |
---|---|---|
校園招聘 | 信息 1 | 1 |
社會招聘 | 信息 2 | 2 |
內部推薦 | 信息 3 | 3 |
獵頭推薦 | 信息 4 | 4 |
校園招聘 | 信息 5 | 5 |
社會招聘 | 信息 6 | 6 |
內部推薦 | 信息 7 | 7 |
獵頭推薦 | 信息 8 | 8 |
校園招聘 | 信息 9 | 9 |
社會招聘 | 信息 10 | 10 |
題目一:
查詢新進類型中,不同原因的合計人數以及人數排名。
結果輸出原因、人數、排名。
題目二:
排名第 4 的原因是什么?對應人數為多少?
填寫示例:社會招聘 20
題目一:思路:排名當然dense_rank排序了,然后其余直接查詢就好
SELECTreason,COUNT(*) AS num_people,DENSE_RANK() OVER (ORDER BY COUNT(*) DESC) AS rk
FROM new_hires
GROUP BY reason
ORDER BY rk;
題目二:搜索對應rank =4的即可
WITH t1 AS (SELECTreason,COUNT(*) AS num_people,DENSE_RANK() OVER (ORDER BY COUNT(*) DESC) AS rkFROM new_hiresGROUP BY reason
)
SELECTreason,num_people
FROM t1
WHERE rk = 4;
或者利用order by desc limit offset即可
SELECTreason,COUNT(*) AS num_people
FROM new_hires
GROUP BY reason
ORDER BY num_people DESC -- 降序排列,人數最多的在前
LIMIT 1 OFFSET 3; -- 跳過前3名,取第4名