SQL每日一题(5)
前言:五更!五更琉璃!不对!是,五更佩可!
原始数据:
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排序了,然后其余直接查询就好
SELECT reason, 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 ( SELECT reason, COUNT(*) AS num_people, DENSE_RANK() OVER (ORDER BY COUNT(*) DESC) AS rk FROM new_hires GROUP BY reason ) SELECT reason, num_people FROM t1 WHERE rk = 4;
或者利用order by desc limit offset即可
SELECT reason, COUNT(*) AS num_people FROM new_hires GROUP BY reason ORDER BY num_people DESC -- 降序排列,人数最多的在前 LIMIT 1 OFFSET 3; -- 跳过前3名,取第4名
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们。