窗口函数不支持在OVER()中使用LIMIT,正确分页需先用ROW_NUMBER()等生成序号,再在外层WHERE中筛选范围;ORDER BY必须包含唯一字段(如主键)以保证分页稳定性。窗口函数本身不支持 LIMIT,别在 OVER() 里写 LIMIT窗口函数(如 ROW_NUMBER()、RANK())是计算值的,不是筛选行的。你在 OVER() 子句里加 LIMIT 会直接报错,比如 PostgreSQL 报 syntax error at or near "LIMIT",MySQL 8.0 也一样不认。真正想分页,得把窗口函数结果当成子查询或 CTE 的一部分,再在外层用 LIMIT + OFFSET(或 FETCH FIRST)控制输出行数。错误写法:SELECT *, ROW_NUMBER() OVER (ORDER BY id) AS rn FROM t LIMIT 10 ------ 这只限制最终结果,但 ROW_NUMBER() 仍基于全表计算,性能差且语义不清正确思路:先算好序号,再筛指定范围,比如第 2 页(每页 10 条)就取 rn BETWEEN 11 AND 20注意:窗口函数执行顺序早于 LIMIT,所以外层过滤必须靠 WHERE 或 HAVING,不能指望 LIMIT 帮你"截断"窗口逻辑用 ROW_NUMBER() 实现稳定分页,ORDER BY 必须唯一如果只按 created_at 排序,而多行时间相同,ROW_NUMBER() 会任意分配不同序号,导致同一页数据每次查出来不一致,甚至漏行、重复。解决办法是在 ORDER BY 里补一个唯一字段兜底,通常是主键: RedClaw 百度推出的手机端万能AI Agent助手
相关推荐
Ice星空2 小时前
使用 uv 进行 python 项目管理m0_514520572 小时前
Go语言怎么做自动补全_Go语言CLI自动补全教程【经典】JaydenAI2 小时前
[FastMCP设计、原理与应用-17]从服务器向客户端的反向通知m0_747854522 小时前
php怎么使用PHP PM热重启_php如何零停机更新生产环境代码cyber_两只龙宝2 小时前
【Oracle】Oracle数据库的登录验证四维迁跃2 小时前
如何提升SQL数据更新的安全性_使用行级锁与悲观锁机制老刘说AI2 小时前
Text2SQL到数据智能knight_9___2 小时前
RAG面试篇10格林威2 小时前
面阵相机 vs 线阵相机:堡盟与海康相机选型差异全解析+python实战演示