SQL统计各分组中排名前三的记录_使用窗口函数RANK

RANK() 遇相同值并列且跳号,如三个第1名后直接第4名;若仅用 WHERE rank ≤ 3 过滤,会漏掉并列第3名之后实际应入选的并列名次,导致结果偏少而非偏多------题干"多出几条"通常源于误将 RANK() 与 ROW_NUMBER() 混淆或未正确处理分组边界。用 RANK() 统计每组前三名时,为什么结果总多出几条?因为 RANK() 遇到相同值会并列且跳号,比如三个并列第1名后,下一个是第4名。如果你只写 WHERE rank ,可能实际返回5条甚至更多记录------只要它们都卡在"第1名"或"第2名"这种并列位置上。真实场景中,用户要的是"最多三条",不是"所有排名≤3的",这时该用 DENSE_RANK() 或加限制逻辑RANK() 适合强调名次断层(如"冠军、亚军、季军,之后是第五名"),不适合取固定数量MySQL 8.0+、PostgreSQL、SQL Server 都支持,但 SQLite 默认不支持窗口函数(需 3.25+ 且编译时启用)怎么写出真正每组只取三条的 SQL?核心是先算排名,再对每个分组做行数截断。别在 WHERE 里直接筛 RANK(),而要用子查询或 CTE 包一层:SELECT user_id, dept, scoreFROM ( SELECT user_id, dept, score, RANK() OVER (PARTITION BY dept ORDER BY score DESC) AS rk FROM users_score) tWHERE t.rk <= 3;必须把 RANK() 放在子查询或 CTE 里,否则窗口函数不能出现在 WHERE 中排序字段如果有 NULL,默认排在最前(PostgreSQL)或最后(MySQL),建议显式写 ORDER BY score DESC NULLS LAST(如果数据库支持)如果某组只有两条数据,RANK() 仍只返回这两条,不会补空行RANK() 和 ROW_NUMBER() 在取前三时差别有多大?差别在是否容忍并列:用 ROW_NUMBER() 每组一定返回最多三条,但相同分数会被强行拆成第1、第2、第3;用 RANK() 则保留业务意义上的并列,但数量不可控。 稿定AI 拥有线稿上色优化、图片重绘、人物姿势检测、涂鸦完善等功能

相关推荐
●VON1 天前
鸿蒙Flutter实战:分类管理页BottomSheet CRUD
数据库·flutter·华为·harmonyos·鸿蒙
Cosolar1 天前
Chroma向量库面试学习指南
数据库·人工智能·面试·职场和发展·数据库架构
风吹夏回1 天前
Python 全局异常处理:从“满屏 try-except”到优雅兜底
开发语言·python
小熊Coding1 天前
Python爬取当当网二手图书项目实战!
开发语言·爬虫·python·beautifulsoup·requests·二手图书
企服AI产品测评局1 天前
Agent适配信创环境实测:企业级自动化如何实现国产操作系统与数据库全兼容?
运维·数据库·人工智能·ai·chatgpt·自动化
秋91 天前
Java项目运行5天左右自动宕机:系统性定位与解决方案
java·开发语言·python
小江的记录本1 天前
【JVM虚拟机】垃圾回收GC:垃圾收集器:CMS:核心原理、回收流程、优缺点、废弃原因(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·面试·maven
cfm_29141 天前
Redis数据安全性解析
数据库·redis·缓存
DIY源码阁1 天前
JavaSwing学生成绩管理系统 - MySQL版
java·数据库·mysql·eclipse
田里的水稻1 天前
OE_ubuntu26.04与宿主机之间复制粘贴内容
人工智能·python·机器人