技术文摘
MySQL 按组区分后获取每组前几名的 SQL 写法
2025-01-14 23:08:22 小编
MySQL 按组区分后获取每组前几名的 SQL 写法
在 MySQL 数据库的实际应用中,我们常常会遇到需要按组区分并获取每组前几名数据的情况。这种需求在数据分析、排行榜生成等场景中十分常见。下面就为大家详细介绍实现这一功能的 SQL 写法。
假设我们有一个学生成绩表 student_scores,包含字段 id(学生编号)、student_name(学生姓名)、class(班级)、score(成绩)。现在我们要获取每个班级成绩排名前三的学生信息。
一种常见的实现方式是使用子查询和 DENSE_RANK() 窗口函数。窗口函数可以为分区内的每一行数据分配一个排名值,方便我们筛选出每组的前几名。
具体的 SQL 语句如下:
WITH RankedScores AS (
SELECT
id,
student_name,
class,
score,
DENSE_RANK() OVER (PARTITION BY class ORDER BY score DESC) AS rank
FROM
student_scores
)
SELECT
id,
student_name,
class,
score
FROM
RankedScores
WHERE
rank <= 3;
在上述代码中,首先使用 WITH 子句创建了一个名为 RankedScores 的临时结果集。在这个临时结果集中,通过 DENSE_RANK() 窗口函数按照 class 进行分区,并在每个分区内按照 score 从高到低排序,为每一行分配一个排名 rank。
然后,在外部查询中从 RankedScores 临时结果集中筛选出 rank 小于等于 3 的数据,即每个班级成绩排名前三的学生信息。
还有一种方法是使用自连接来实现。这种方法的核心思路是通过多次自连接,比较同一班级内学生的成绩,统计出成绩比当前学生高的人数。如果这个人数小于 3,那么该学生就是班级内成绩排名前三的。
SELECT
s1.id,
s1.student_name,
s1.class,
s1.score
FROM
student_scores s1
WHERE
(SELECT COUNT(*)
FROM student_scores s2
WHERE s1.class = s2.class AND s1.score < s2.score) < 3
ORDER BY
s1.class, s1.score DESC;
这种写法相对复杂一些,但同样可以达到获取每组前几名的目的。在实际应用中,我们可以根据数据库的性能、数据量以及个人编程习惯来选择合适的方法。掌握这些 SQL 写法,能够帮助我们更加高效地处理数据,满足各种复杂的业务需求。
- JavaScript 性能优化技术在 React 与 Nextjs 中的应用
- 准备应用程序应对黑色星期五的多个请求方法
- Element 表格中如何借助 template 解决一行与两行显示问题
- 前端调用后端获取 HTML 链接时出现下载文件情况怎么处理
- 开源!流畅视频滑动的 Web 应用程序
- Vue 中 Select 标签 v-on:change 事件只执行一次的解决办法
- CSS检测操作系统是否处于暗模式的方法
- 原生 JavaScript 实现类似企业微信树形效果的插件推荐
- CSS 实现齿状圆环渐变透明效果的方法
- CSS 最佳实践:后端程序员重温 CSS 时的三大常见疑问
- 圆形容器中居中放置超链接的方法
- Meta 标签能否控制 HTML 缓存
- 怎样达成带内环阴影的圆环进度条效果
- 提升性能秘籍:React 自动批处理实现最小化重新渲染
- 如何移除组件输入框的背景颜色(中)