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名
相关推荐
键盘上的猫头鹰1 小时前
【MySQL 教程(八)】索引、事务、用户管理、导入导出与分页查询
数据库·python·mysql
Royzst1 小时前
数据库知识点
数据库
雪的季节2 小时前
企业级 Qt 全功能项目
开发语言·数据库·qt
宋浮檀s2 小时前
应急响应——Web漏洞:命令执行+SSRF+弱口令
运维·数据库·sql·网络安全·oracle·应急响应
yurenpai(27届找实习中)3 小时前
redis_点评(21.好友关注——关注、取关功能实现;共同关注功能实现)
数据库·redis·缓存
Rick19933 小时前
索引的排序和分组
数据库·mysql
爱莉希雅&&&3 小时前
zabbix快速搭建和使用
android·linux·数据库·zabbix·监控
JohnYan4 小时前
工作笔记 - PG分组极值
数据库·后端·postgresql
清溪5494 小时前
DataEase H2 JDBC-RCE(CVE-2025-32966)复现
数据库·安全
ServBay4 小时前
不要再盲选了,PostgreSQL、MySQL与SQLite真实性能对比
数据库·mysql·sqlite