窗口函数不支持在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助手
相关推荐
曲幽1 小时前
FastAPI 身份验证总踩坑?这份 FastAPI Users “避坑指南”请收好素材积累2 小时前
博士后出站来深可申请的项目补贴等装不满的克莱因瓶2 小时前
掌握 RNN 与 LSTM 模型结构何以解忧,唯有..2 小时前
Python包管理工具pip:从入门到精通金銀銅鐵2 小时前
用 Tkinter 实现简单的猜数字游戏copyer_xyf3 小时前
Python 模块与包的导入导出_1_73 小时前
SQL Server 磁盘满了 收缩日志ice8130331813 小时前
【Python】Matplotlib折线图绘制copyer_xyf3 小时前
Python venv 虚拟环境basketball6163 小时前
Redis基础:1. Redis介绍