GROUP BY 配合 MAX()/MIN() 是统计每组最大最小值最直接可靠的方式,需确保 SELECT 中非聚合字段均出现在 GROUP BY 中,NULL 自动忽略,索引应为(分组字段,聚合字段)以提升性能。GROUP BY 后直接用 MAX() 和 MIN() 就行SQL 里统计每组最大最小值,不需要子查询或窗口函数(除非你要保留原始行),MAX() 和 MIN() 配合 GROUP BY 是最直觉也最稳妥的方式。它在所有主流数据库(MySQL、PostgreSQL、SQL Server、SQLite)里行为一致,语义清晰。常见错误是试图在没 GROUP BY 的情况下混用聚合和非聚合字段,比如:SELECT category, MAX(price), name FROM products; ------ 这在严格模式下直接报错,因为 name 没参与分组也没聚合,数据库不知道该取哪一行的 name。必须确保 SELECT 中所有非聚合字段都出现在 GROUP BY 子句中如果想同时拿到最高价那条记录的完整信息(比如商品名、ID),MAX() 本身做不到,得换 ROW_NUMBER() 或相关技巧空值(NULL)会被自动忽略------除非整组全是 NULL,此时 MAX()/MIN() 返回 NULL遇到 ONLY_FULL_GROUP_BY 报错怎么办MySQL 5.7+ 默认开启 ONLY_FULL_GROUP_BY 模式,一写错就报类似 Expression #2 of SELECT list is not in GROUP BY clause 的错误。这不是 bug,是 SQL 标准在强制你写清楚意图。别急着关掉这个模式(关了反而埋坑),先检查你的 SELECT 列:哪些是分组键,哪些是聚合结果,哪些是"多余"的。例如:SELECT dept, MAX(salary), employee_name FROM staff GROUP BY dept;这里 employee_name 没聚合也没分组,MySQL 拒绝执行。解决方法只有两个:删掉 employee_name(如果你真只需要部门最高薪数值)改用聚合函数包裹它,比如 MAX(employee_name)(语义变了,取的是字典序最大名字,不是最高薪那个人)MAX() 和 MIN() 能用在非数字字段上吗能,而且很常用。它们按字段类型的自然顺序比较:字符串按字典序,日期按时间先后,布尔值按 FALSE TRUE。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
小白考证进阶中19 分钟前
Oracle OCP证书报考&考试全指南星恒随风30 分钟前
Python 基础语法详解(一):从表达式、变量到数据类型888CC++32 分钟前
java 并发编程Dxy123931021637 分钟前
python缩放图片如何保证图片质量Leon-Ning Liu1 小时前
【真实经验分享】 ORA-600 [qesmaGetTblSeg1]与数据交流的路上1 小时前
MySQL 优化 -- 相关ZHW_AI课题组1 小时前
腾讯云调用IP定位Rooting++1 小时前
为什么mysql的表字段的collation会自动变Wch1G0z8A1 小时前
Google 开源了啥,让 AI Agent 碰数据库不再是定时炸弹zhaoshuzhaoshu1 小时前
Python文件操作详细解析带例子