应使用 ROW_NUMBER() 窗口函数实现严格序号排名:先按目标列降序排序并辅以唯一字段确保稳定性,再在外部查询中过滤掉当前行且取排名≤N的记录;不可在 WHERE 中直接调用窗口函数。用 ROW_NUMBER() 排名后跳过自己想取前 N 个最大值但排除当前行,本质是「按某列降序排,取排名 ≤ N 的行,再过滤掉自己」。窗口函数最直接的解法就是 ROW_NUMBER():它严格按排序顺序给唯一序号,不会并列,适合做"第1、第2、第3..."这种硬性截断。常见错误是误用 RANK() 或 DENSE_RANK() ------ 它们遇到相同值会并列,导致实际返回行数不稳定(比如两个并列第1,RANK() = 1 就有两行,ROW_NUMBER() 则一定是唯一编号)。必须在 ORDER BY 子句中明确指定排序依据,且最好包含主键或唯一字段作为第二排序条件,避免因排序不稳定导致每次执行结果不一致别在 WHERE 里直接写 ROW_NUMBER() OVER (...) ------ 窗口函数不能出现在 <code>WHERE,得先套一层子查询或 CTE示例:查销售额前3高的客户,但排除当前客户(假设当前客户 ID 是 123):SELECT * FROM ( SELECT *, ROW_NUMBER() OVER (ORDER BY sales DESC, customer_id) AS rn FROM customers) t WHERE rn <= 3 AND customer_id != 123;用 LAG() / LEAD() 做相对位移时的陷阱如果目标不是"全局前N",而是"比自己高第K位的那条记录",比如"上一名的销售额是多少",这时候 LAG() 更合适。但它不解决"排除自己取前N"这个需求,强行用反而绕路且易错。典型误用:试图用 LAG(sales, 1) 拿上一名,再层层嵌套到第N层------逻辑爆炸,且一旦中间有并列值,位移就错位。 Mokker AI AI产品图添加背景
相关推荐
KobeSacre4 分钟前
JVM ZGCPsycho_MrZhang7 分钟前
Codex 高效开发协作手册HappyAcmen19 分钟前
1.pdfplumber安装,PDF文字提取弹简特20 分钟前
【零基础学Python-收尾】10-Python第三方库的安装介绍itfallrain33 分钟前
Spring 构造器循环依赖排查:@RequiredArgsConstructor + @Lazy 到底有没有生效Database_Cool_1 小时前
AnalyticDB MySQL vs StarRocks/ByteHouse:云数仓选型指南——全托管 vs 自建方案小草cys1 小时前
NVIDIA 驱动(550版本)成功安装后安装支持 GPU 加速的 PyTorchSilentSamsara1 小时前
Python 微服务全链路:gRPC + 链路追踪 + 服务网格接入Omics Pro1 小时前
「自兹以往」动物肠道微生物组zzz_23681 小时前
【Redis】分布式锁完整演进