SQL窗口函数解决多维排名问题_组合排序实战

rank() 跳号并列后空位,dense_rank() 连续编号不跳号;row_number() 强制唯一序号;分组需 PARTITION BY,NULL 排序需 NULLS LAST,窗口函数不可用于 WHERE。rank() 和 dense_rank() 差在哪?一查排名就错多维排序时用 rank() 得到"1,1,3,3,5"这种跳号结果,但业务要的是"1,1,2,2,3"------这不是数据错了,是函数选错了。dense_rank() 才是连续编号的正确选择;rank() 会为并列项腾出后续位置,row_number() 则强行打乱序号(哪怕值相同)。常见错误现象:ORDER BY score DESC 后发现同一分数被分到不同名次;或导出报表时"第2名"直接消失。按部门分组内排名:必须写 PARTITION BY dept_id,漏掉就变成全表排了排序字段含 NULL:默认排最前,若要排最后得加 NULLS LAST(PostgreSQL/Oracle 支持,MySQL 8.0 不支持)多个排序条件:写成 ORDER BY salary DESC, hire_date ASC,别用逗号隔开两个 ORDER BYMySQL 8.0 窗口函数报错 "This function is not allowed in this context"不是语法错,是 MySQL 对窗口函数的使用位置极其敏感:不能出现在 WHERE、GROUP BY 或普通子查询里,只能在 SELECT 列表或 HAVING 中直接调用。典型翻车场景:想筛出"部门内薪资前3的员工",写了 WHERE dense_rank() OVER (...) ------ 直接报错。正确做法:套一层子查询或 CTE,先算排名,再在外层 WHERE 过滤CTE 写法更清晰:WITH ranked AS (SELECT *, dense_rank() OVER (PARTITION BY dept_id ORDER BY salary DESC) rnk FROM emp)MySQL 8.0 不支持 RANGE BETWEEN,别抄 PostgreSQL 文档里的高级帧定义多字段组合排序时 order by 的字段顺序影响最终排名窗口函数的 ORDER BY 不是"先按 A 排、再按 B 排"的简单叠加,而是构建一个复合排序键。A 字段相同时才比较 B,但只要 A 不同,B 完全不参与当前行的名次判定。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。

相关推荐
顾林海1 小时前
Agent入门阶段-编程基础-Python:流程控制
python·agent·ai编程
呱呱复呱呱4 小时前
Django CBV 源码解读:一个请求是怎么找到你的 get() 方法的
python·django
Nturmoils5 小时前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
曲幽9 小时前
刚部署的 LibreTranslate 频频翻车?我掏出了 20 年前的 StarDict 词典,用 FastAPI 搭了个本地词典翻译 API
python·fastapi·web·translate·goldendict·libretranslate·stardict·pystardict
渣波9 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
荣码9 小时前
用Streamlit给AI应用套个界面,10行代码出Web页面
java·python
兵慌码乱19 小时前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理
金銀銅鐵20 小时前
[Python] 体验用欧几里得算法计算最大公约数的过程
python·数学
FreakStudio1 天前
W55MH32L-EVB 上手测评:硬件 TCP/IP 加持的以太网单片机,MicroPython 零门槛开发
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机
用户0332126663671 天前
使用 Python 从零创建 Word 文档
python