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助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
Aision_17 小时前
从工具调用到 MCP、Skill完整学习记录辞旧 lekkk21 小时前
【Qt】信号和槽2301_809204701 天前
JavaScript中严格模式use-strict对引擎解析的辅助.txtzjy277771 天前
mysql如何选择合适的索引类型_mysql索引设计实战Aaswk1 天前
Java Lambda 表达式与流处理笨蛋不要掉眼泪1 天前
Mysql架构揭秘:update语句的执行流程万邦科技Lafite1 天前
京东item_get接口实战案例:实时商品价格监控全流程解析秋91 天前
ruoyi项目更换为mysql9.7.0数据库Andya_net1 天前
MySQL | MySQL 8.0 权限管理实践-精确赋予库、表只读等权限Cyber4K1 天前
【Python专项】进阶语法-系统资源监控与数据采集(1)