news 2026/4/20 4:51:34

SQL如何统计分组内的最高和最低值_MAX与MIN聚合应用

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SQL如何统计分组内的最高和最低值_MAX与MIN聚合应用

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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/20 4:51:32

算法训练营第7天|环形链表判定 142. 环形链表

题目链接: https://leetcode.cn/problems/linked-list-cycle-ii/ 视频链接: https://www.bilibili.com/video/BV1if4y1d7ob​​​​​​ 我的代码: https://leetcode.cn/problems/linked-list-cycle-ii/submissions/719511152 看到题目的…

作者头像 李华
网站建设 2026/4/20 4:49:13

Hunyuan-MT Pro开源大模型教程:基于Hunyuan-MT-7B微调定制行业词典方法

Hunyuan-MT Pro开源大模型教程:基于Hunyuan-MT-7B微调定制行业词典方法 1. 引言:为什么需要定制行业词典? 在机器翻译的实际应用中,通用翻译模型往往难以准确处理特定行业的专业术语。比如医疗领域的"myocardial infarctio…

作者头像 李华
网站建设 2026/4/20 4:43:07

Go语言如何做图片缩放_Go语言图片缩放裁剪教程【推荐】

imaging.Resize 一用就变形是因为默认强制拉伸而非等比缩放;传0可让某方向自适应,Fit留白、Fill裁剪;Crop需手动计算左上角坐标并校验越界,顺序应先缩再裁;插值器选ApproxBiLinear更稳妥。imaging.Resize 为什么一用就…

作者头像 李华
网站建设 2026/4/20 4:43:04

HTML怎么显示速率限制重置时间_HTML X-RateLimit-Reset解析【说明】

需后端在Access-Control-Expose-Headers中暴露X-RateLimit-Reset,前端用Date.parse(response.headers.get(Date))获取服务端当前时间,再与X-RateLimit-Reset(秒级时间戳1000)做差计算剩余秒数,避免客户端时钟偏差。怎么…

作者头像 李华
网站建设 2026/4/20 4:42:14

面试官:Skills是什么?讲一讲它的工作原理

一、标准答案参考 直接上答案:Skills本质是结构化的本地文件夹,用来补充某个领域的流程、知识和工具,让模型在相关场景下自动或按需调用,是面向大模型的能力封装。 二、扩展问题 1、Skills 和 Prompt 的区别是什么? …

作者头像 李华
网站建设 2026/4/20 4:40:19

为什么你的AI Agent响应速度总是不达标:延迟优化与性能调优实战复盘

为什么你的AI Agent响应速度总是不达标:延迟优化与性能调优实战复盘1. 引入与连接:从一场“凌晨三点的客户退单”说起 1.1 核心概念 在正式拆解AI Agent延迟问题之前,我们必须先锚定两个最核心、最容易被混淆的前置概念,并通过它们…

作者头像 李华