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助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。

相关推荐
清溪5494 分钟前
pgAdmin4 <= 9.1_RCE(CVE-2025-2945)复现
数据库·后端
我的xiaodoujiao4 分钟前
API 接口自动化测试详细图文教程学习系列24--如何用Pytest去设计接口测试用例并执行
python·学习·测试工具·pytest
清溪54919 分钟前
pgAdmin4后台Restore RCE(CVE-2025-13780)复现
数据库·后端
zhangfeng113326 分钟前
ai 模型加密,强化版终极防盗方案 支持烧录的显卡列表
人工智能·pytorch·python
半个落月27 分钟前
深入理解 Python dict 与 set:从哈希表底层到高性能实战
python
带派擂总32 分钟前
Python全栈开发 Day10_用户管理系统
python
databook38 分钟前
用 SymPy 解决 Manim 曲线绘制速度不均的问题
python·数学·动效
宇宙无敌程序员菜鸟39 分钟前
浅玩CRUD Agent
python
程序大视界40 分钟前
【Python系列课程】Python入门教程
开发语言·人工智能·python
煎饼皮皮侠43 分钟前
【设计】设计一个web版的数据库管理平台后端(之三) -- 多数据库通用分页
数据库·web数据库·查询平台