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名
相关推荐
GJCTYU1 小时前
spring中@Transactional注解和事务的实战理解附代码
数据库·spring boot·后端·spring·oracle·mybatis
MicroTech20251 小时前
微算法科技(NASDAQ: MLGO)探索Grover量子搜索算法,利用量子叠加和干涉原理,实现在无序数据库中快速定位目标信息的效果。
数据库·科技·算法
Code季风1 小时前
SQL关键字快速入门:CASE 实现条件逻辑
javascript·数据库·sql
weixin_478689761 小时前
操作系统【2】【内存管理】【虚拟内存】【参考小林code】
数据库·nosql
九皇叔叔2 小时前
【7】PostgreSQL 事务
数据库·postgresql
kk在加油2 小时前
Mysql锁机制与优化实践以及MVCC底层原理剖析
数据库·sql·mysql
Kookoos2 小时前
ABP VNext + Cosmos DB Change Feed:搭建实时数据变更流服务
数据库·分布式·后端·abp vnext·azure cosmos
hello 早上好3 小时前
MsSql 其他(2)
数据库·mysql
高压锅_12203 小时前
SQLAlchemy数据库连接密码特殊字符处理完全指南
数据库·mysql·django·sqlalchemy
Hello.Reader8 小时前
Redis 延迟监控深度指南
数据库·redis·缓存