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 拥有线稿上色优化、图片重绘、人物姿势检测、涂鸦完善等功能
相关推荐
JdSnE27zv2 分钟前
数据库表字段命名规范隔窗听雨眠10 分钟前
ORM框架选型指南:MyBatis与Hibernate的全面对比ZHW_AI课题组10 分钟前
使用Stable Diffusion v1.5文本引导与无分类器引导(CFG)算法实现条件生成图片tedcloud12310 分钟前
Dolt部署教程:打造可追踪数据变更的数据库环境盼小辉丶11 分钟前
OpenCV-Python实战(25)——基于深度传感器与凸性分析打造实时手势识别系统金融大 k15 分钟前
行情数据接入 MCP:Claude Code / Cursor 工具描述怎么写才不踩坑jameslogo18 分钟前
JVM执行引擎数据库小学妹19 分钟前
MySQL 误删数据恢复全流程:Binlog 回放+全量备份+延迟从库三种方案实战张彦峰ZYF24 分钟前
深入 LangGraph State:Reducer 是如何让状态“自动合并”的TDengine (老段)28 分钟前
TDengine Cache 与 Last 查询加速 — CACHEMODEL 机制与 RocksDB 缓存层