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名
相关推荐
后端漫漫16 分钟前
Redis 客户端工具体系
数据库·redis·缓存
PaperData1 小时前
1988-2025年《中国人口和就业统计年鉴》全年份excel+PDF
数据库·人工智能·数据分析·经管
星河耀银海2 小时前
C语言与数据库交互:SQLite实战与数据持久化
c语言·数据库·sqlite·交互
过期动态2 小时前
MySQL中的约束
android·java·数据库·spring boot·mysql
程序员陆通2 小时前
月烧 400 刀到不到 20 刀:我是怎么把 OpenClaw 的 Token 账单砍掉 95% 的
java·前端·数据库
Shan12052 小时前
站在计算机领域视角看:SQL注入攻击
网络·数据库·sql
轻刀快马3 小时前
别干背八股文了:从一场“双十一秒杀”惨案,看懂 InnoDB 事务、锁与索引的底层齿轮
数据库·sql
万事大吉CC3 小时前
【1】Django 基础:MTV 架构与核心组件
数据库·架构·django
曾凡宇先生3 小时前
mysql局域网授权
数据库·mysql
xcLeigh4 小时前
IoTDB Rust 原生接口开发指南:从零生成 + 完整 RPC 调用
数据库·rpc·rust·接口·api·时序数据库·iotdb