应使用 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产品图添加背景
相关推荐
wj3055853785 小时前
课程 9:模型测试记录与 Prompt 策略星寂樱易李5 小时前
iperf3 + Python-- 网络带宽、网速、网络稳定性qingfeng154156 小时前
企业微信机器人开发:如何实现自动化与智能运营?星星也在雾里6 小时前
PgBouncer 解决 PostgreSQL 连接数超限 + 可视化监控AI人工智能+电脑小能手7 小时前
【大白话说Java面试题 第65题】【JVM篇】第25题:谈谈对 OOM 的认识雨辰AI8 小时前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战长城20248 小时前
关于MySql的ONLY_FULL_GROUP_BY问题常常有8 小时前
MySQL 底层执行原理:输入SQL语句到两阶段提交Mr. zhihao9 小时前
深入解析redis基本数据结构