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助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
A-刘晨阳1 天前
AI原生时序数据库选型指南:从数据存储到智能决策的范式跃迁HalvmånEver1 天前
MySQL的增删改查命令合集合集不剪发的Tony老师1 天前
dblab:一款基于终端的交互式数据库客户端YJlio1 天前
7.4.5 Windows 11 企业网络连接与网络重置实战:远程访问、本地策略与故障恢复深耕AI1 天前
【VS Code避坑指南】点击Python图标提示“没有Python环境”,选择安装uv后这堆输出到底是什么意思?第一程序员1 天前
Rust生命周期管理实战指南:从困惑到掌握程序员威哥1 天前
实战!Python爬京东商品评论:从采集到情感分析+词云可视化,新手30分钟跑通风噪1 天前
centos7 python3.13全套安装(可用于离线复制)xwz小王子1 天前
Science Robotics基础模型正在改写机器人集群的“游戏规则”茉莉玫瑰花茶1 天前
LangGraph 介绍