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 拥有线稿上色优化、图片重绘、人物姿势检测、涂鸦完善等功能

相关推荐
qq_432703662 小时前
CSS如何去掉数字输入框的默认微调按钮_利用---webkit-inner-spin-button
jvm·数据库·python
Irene19912 小时前
Oracle 数据库表操作总结(新建表,删除表,表的增删改查等)
数据库·sql·oracle
weixin_580614002 小时前
HTML怎么创建同步设置精细控制_HTML按模块开关同步项【技巧】
jvm·数据库·python
SelectDB技术团队2 小时前
Apache Doris 4.1:面向 AI & Search 的统一数据存储与检索底座
数据库·数据仓库·实时分析·selectdb
maqr_1102 小时前
Golang怎么对接ChatGPT_Golang ChatGPT教程【简明】
jvm·数据库·python
m0_514520572 小时前
JavaScript中函数声明位置对解析器预编译的影响
jvm·数据库·python
m0_743623922 小时前
SQL多维度统计优化_GROUP BY索引组合设计
jvm·数据库·python
AI是这个时代的魔法2 小时前
Unpack Nested Data:照亮你的数据结构
数据结构·python
Greyson12 小时前
HTML怎么创建时间轴布局_HTML结构化时间线写法【方法】
jvm·数据库·python