SQL在GROUP BY中如何保留非聚合列_配合ANY_VALUE或窗口函数

应使用ANY_VALUE()显式声明非确定性取值,或用窗口函数实现"每组取最新一条"等明确逻辑,避免关闭ONLY_FULL_GROUP_BY导致数据不可靠。MySQL 8.0+ 中 GROUP BY 报错 "Expression #1 of SELECT list is not in GROUP BY clause" 怎么办这是 MySQL 严格模式下的典型报错,本质不是语法错误,而是 SQL 模式(sql_mode)拒绝"非确定性选择"。比如你写了 SELECT id, name, COUNT(*) FROM users GROUP BY dept,id 和 name 没聚合也没出现在 GROUP BY 里,MySQL 不知道该取哪一行的值。最直接的解法是关掉 ONLY_FULL_GROUP_BY ------ 但不推荐。它掩盖问题,上线后可能返回任意行,查到的数据不可靠。用 ANY_VALUE() 显式声明"我就要随便取一个",语义清晰,兼容 MySQL 5.7.5+用窗口函数(如 ROW_NUMBER() OVER (PARTITION BY dept ORDER BY created_at DESC))先排序再过滤,适合"每组取最新一条"这类明确逻辑如果只是想查分组统计 + 某个代表值(比如部门负责人),建议提前在子查询或 CTE 里把代表值算好,再和分组结果 JOINANY_VALUE() 看似简单,但容易忽略的三个行为细节ANY_VALUE() 不是随机函数,也不是取首行,它是"优化器自由选择的一行值"------具体选哪行取决于执行计划、索引、数据分布,甚至 MySQL 版本升级都可能变。所以它只适用于你真不在乎是哪一行的场景。不能用于主键或唯一列的"去重替代",比如 ANY_VALUE(id) 在 GROUP BY name 下可能返回任意匹配的 id,无法保证一致性和 ORDER BY 同时用没意义:SELECT ANY_VALUE(name) FROM t GROUP BY dept ORDER BY dept 中的 ORDER BY 不影响 ANY_VALUE() 的取值在视图或物化查询中使用时,如果底层表加了索引,ANY_VALUE() 可能稳定返回索引顺序的第一行,但这属于实现细节,不应依赖想"每组取最新一条",为什么别硬套 ANY_VALUE() 而要用窗口函数因为 ANY_VALUE() 解决不了"按时间/优先级选"的需求。例如"每个部门最新入职的员工",ANY_VALUE() 可能返回三年前的老员工,而你要的是 created_at 最大的那条。窗口函数才是正解: 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。

相关推荐
兵慌码乱6 小时前
基于 MediaPipe 与 PySide2 的手势交互音乐控制系统实现:轻量化视觉交互全流程解析
python·opencv·计算机视觉·人机交互·手势识别·mediapipe·pyside2
luckdewei9 小时前
FastAPI 资产管理系统实战:复杂 ORM 关联、Alembic 迁移与 N+1 查询优化
python
aqi0015 小时前
15天学会AI应用开发(八)使用向量数据库实现RAG功能
人工智能·python·大模型·ai编程·ai应用
Csvn16 小时前
`functools.lru_cache` —— 一行代码搞定缓存加速
后端·python
金銀銅鐵1 天前
[Python] 从《千字文》中随机挑选汉字
后端·python
cup112 天前
[技术复盘] Windows Python 打包实战:Nuitka 环境踩坑总结与 CI 自动化构建全指南
python·ai·环境变量·ci·nuitka·skill
aqi002 天前
15天学会AI应用开发(七)有了大模型为什么还要引入RAG
人工智能·python·大模型·ai编程·ai应用
金銀銅鐵2 天前
用 Python 实现 Take-Away 游戏
python·游戏