SQL如何在分组查询中包含所有行数据_使用窗口函数OVER PARTITION

GROUP BY后查不到非聚合字段的原始值是因SQL标准要求SELECT列须在GROUP BY中或为聚合结果;窗口函数如ROW_NUMBER()可按PARTITION BY分组排序取最新行,但需注意NULL分组、排序确定性等细节。为什么 GROUP BY 后查不到非聚合字段的原始值因为标准 SQL 要求 SELECT 列要么是 GROUP BY 的字段,要么是聚合函数(如 MAX()、COUNT())的结果。直接写 SELECT id, name, COUNT(*) FROM t GROUP BY type 会报错:column "id" must appear in the GROUP BY clause or be used in an aggregate function。这不是数据库"限制",而是语义问题:同一组里有多个 id,数据库不知道你要哪一条。窗口函数能绕过这个限制------它不改变行数,只是给每行"附加工具计算结果":OVER (PARTITION BY type) 表示按 type 分组计算,但保留原表每一行每行仍能访问自己的 id、name,同时拿到该 type 组的统计值常见误用:把 OVER 当成 GROUP BY 的替代品去"去重"或"收缩结果集",其实它完全不收缩怎么用 ROW_NUMBER() / RANK() / FIRST_VALUE() 配合 PARTITION BY 取分组内某行数据想在分组中取"每个 type 最新一条记录"?不能靠 GROUP BY + MAX(created_at) 再关联回去------太绕且易错。直接用窗口函数定位:ROW_NUMBER() OVER (PARTITION BY type ORDER BY created_at DESC):给每组内按时间倒序编号,1 就是最新那条FIRST_VALUE(id) OVER (PARTITION BY type ORDER BY created_at DESC):直接取每组最新记录的 id(注意:需搭配 ROWS BETWEEN UNBOUNDED PRECEDING AND UNBOUNDED FOLLOWING 才稳定,否则默认窗口可能只到当前行)别用 RANK() 取"第一条"------并列时会返回多个 1,而 ROW_NUMBER() 强制唯一排序示例(取每组最新完整行): 稿定AI 拥有线稿上色优化、图片重绘、人物姿势检测、涂鸦完善等功能

相关推荐
掉头发的王富贵1 小时前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
Nturmoils1 小时前
WHERE 条件别凭习惯写,常用查询先跑一遍
数据库
荣码6 小时前
LangGraph多Agent协作:3个Agent干活比1个强,但我踩了4个坑
java·python
用户83562907805121 小时前
Python 操作 PDF 附件:添加、查看与管理指南
后端·python
Databend1 天前
在 AWS 中国峰会逛了一天,我在 Databend 展台看到了 Agent 数据基础设施的新思路
数据库·人工智能·agent
宇宙之一粟1 天前
乐企版式文件生成平台
java·后端·python
学测绘的小杨2 天前
CompassFusion:一个从 GNSS 到 GNSS/INS 组合导航的独立工程包
python
ClouGence2 天前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
zzzzzz3102 天前
当产品经理说这个很简单:我用Python自动化处理奇葩需求的实战指南
python·pycharm·产品经理
雪隐2 天前
个人电脑玩AI-06让5060 Ti给你打工——不光能画画,Qwen3-TTS还能学人说话,连我老板都信了!
人工智能·后端·python