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助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
DevangLic2 小时前
【量化-因子】baidu_340998822 小时前
JavaScript中函数调用的四种模式及其this绑定优先级表吕源林2 小时前
SQL在JOIN语句中过滤非必要字段_减少传输开销与查询执行时间qq_424098562 小时前
如何在 Go 方法中正确修改切片类型qq_334563552 小时前
如何利用分区进行并行DML_开启会话并行针对不同分区同时执行更新绩隐金2 小时前
SQL Server 开发系列(第八期):事务与并发控制(开发视角)——避免死锁与数据异常z4424753262 小时前
如何高效进行堆叠分类器的超参数调优:解决 GridSearchCV 卡顿问题2301_775148152 小时前
如何操作 XML 数据_XMLTYPE 与 EXTRACT 函数解析节点2402_854808372 小时前
怎么利用Navicat进行调整备份文件压缩等级_详细配置与操作步骤