当前位置: 首页 > news >正文

SQL每日一题(4)

前言:第四更 虽然已经全部做完了,这套卷子非常推荐!

根据题目还原出来的原始表

employees表

idnameagestatus
1张三28在岗
2李四35在岗
3王五42在岗
4赵六NULL在岗
5钱七58在岗
6孙八24在岗
7周九31离职
8吴十-5在岗
9郑十一45在岗
10王十二52在岗

 题目1:

查询在岗员工各个年龄段的人数,结果输出年龄段及对应的人数,按年龄段升序排序。
年龄段划分及排序(默认左闭右开):25 岁以下,25 - 30 岁,30 - 35 岁,35 - 40 岁,40 - 45 岁,45 - 50 岁,50 - 55 岁,55 岁及以上,异常情况。
结果输出:年龄段,人数。
备注:异常情况 为空值、异常值等

题目2:

人数第 2 多的年龄段是哪个?对应人数是多少?异常情况有多少人?
填写示例:35 - 40 岁 300 10

题目1:思路 利用case when 语句

SELECTCASEWHEN age < 25 THEN '25岁以下'WHEN age >= 25 AND age < 30 THEN '25-30岁'WHEN age >= 30 AND age < 35 THEN '30-35岁'WHEN age >= 35 AND age < 40 THEN '35-40岁'WHEN age >= 40 AND age < 45 THEN '40-45岁'WHEN age >= 45 AND age < 50 THEN '45-50岁'WHEN age >= 50 AND age < 55 THEN '50-55岁'WHEN age >= 55 THEN '55岁及以上'ELSE '异常情况'END AS age_group,COUNT(*) AS num_people
FROM employees
GROUP BY age_group  -- 使用列别名分组
ORDER BYCASE age_group  -- 直接对age_group进行排序WHEN '25岁以下' THEN 1WHEN '25-30岁' THEN 2WHEN '30-35岁' THEN 3WHEN '35-40岁' THEN 4WHEN '40-45岁' THEN 5WHEN '45-50岁' THEN 6WHEN '50-55岁' THEN 7WHEN '55岁及以上' THEN 8ELSE 9END;

   题目二:思路将题目1转换为t1表,在对t1表进行row_number()窗口函数进行排序结合order by即可搜索,其他直接查询

查询第二年龄段的人数 

WITH t1 AS (SELECTCASE ... END AS age_group,COUNT(*) AS num_peopleFROM employeesGROUP BY age_group
),
t2 AS (SELECTnum_people,age_group,DENSE_RANK() OVER (ORDER BY num_people DESC) AS rkFROM t1
)
SELECT num_people,age_group
FROM t2
WHERE rk = 2;

查询异常人数 直接从employees表进行查询即可 

SELECT COUNT(*) AS num异常 
FROM employees 
WHERE age IS NULL OR age <= 0;

相关文章:

  • 【动态规划】简单多状态(二)
  • 枚举类扩充处理
  • 前端框架6
  • 解决 Supabase “permission denied for table XXX“ 错误
  • [iic]iic四参数函数设备地址,寄存器地址,数据内容,数据长度
  • vue 引入配置的常量时,常量内部怎么引用 vue 中的值
  • 从 0 开始部署 Archivematica (windows环境)
  • Thinkphp6使用token+Validate验证防止表单重复提交
  • 如何进行Appium实现移动端UI自动化测试?
  • [C++]洛谷B3626 跳跃机器人(题干 + 详细讲解, BFS练习题)
  • 如何评价OpenRouter这样的大模型API聚合平台?
  • C++友元函数和友元类
  • wsl 魔法
  • 【每天一个知识点】“数字人”(Digital Human)
  • 中台项目-微前端qiankun-umimax
  • PCB设计实践(二十七)电感的形态分类与应用场景深度解析
  • 一个国债交易策略思路
  • MySQL快速入门篇---联合查询
  • Mybatis(2)
  • CPU飚高处理经验总结
  • 买公司的网站建设/郑州网络推广排名
  • 北京澳环网站设计中心/百度网络营销中心官网
  • 梅州专业网站建设教程/百度应用商店下载安装
  • 网页设计方案/廊坊seo排名霸屏
  • 国外网站怎样建设/软文是什么文章
  • 东莞疫情政策/seo优化上首页