news 2026/6/4 17:35:18

sql聚合函数

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
sql聚合函数

在 SQL 中,聚合函数(Aggregate Function)是对一组数据行(记录)进行计算并返回单一结果的函数,核心作用是实现数据的统计、汇总分析。它通常与GROUP BY子句配合使用(分组聚合),也可单独用于全表统计,常见于报表、数据分析场景。

一、常用聚合函数(附示例)

以下以经典的score成绩表为例(字段:student_id 学生 ID、subject 科目、score 分数):

函数作用示例(SQL)示例结果
COUNT()统计行数(非 NULL 值的数量)-- 统计总学生数(去重)COUNT(DISTINCT student_id)50(假设 50 个学生)
SUM()计算数值列的总和-- 统计数学科目总分SUM (score) WHERE subject=' 数学'4500(假设)
AVG()计算数值列的平均值-- 计算数学科目平均分AVG (score) WHERE subject=' 数学'90(假设)
MAX()找出列中的最大值-- 数学科目最高分MAX (score) WHERE subject=' 数学'100
MIN()找出列中的最小值-- 数学科目最低分MIN (score) WHERE subject=' 数学'60
GROUP_CONCAT()(MySQL 特有)分组拼接字符串-- 拼接每个学生的科目GROUP_CONCAT(subject) GROUP BY student_id语文,数学,英语
关键说明:
  1. COUNT()的三种用法:
    • COUNT(*):统计所有行数(包括 NULL 值);
    • COUNT(列名):统计该列非 NULL 值的行数;
    • COUNT(DISTINCT 列名):统计该列去重后的非 NULL 值行数。
  2. 聚合函数会自动忽略NULL值(比如某学生某科目分数为 NULL,SUM/AVG不会计算该值)。

二、聚合函数的核心使用规则

1. 单独使用(全表聚合)

无需分组,直接对整张表的目标列统计:

-- 统计成绩表总记录数 SELECT COUNT(*) AS total_records FROM score; -- 统计所有科目总分、平均分、最高分、最低分 SELECT SUM(score) AS total_score, AVG(score) AS avg_score, MAX(score) AS max_score, MIN(score) AS min_score FROM score;
2. 与 GROUP BY 配合(分组聚合)

按指定字段分组,对每组数据分别聚合(最常用场景):

-- 按科目分组,统计每科的总分、平均分、参考人数 SELECT subject, SUM(score) AS total_score, AVG(score) AS avg_score, COUNT(student_id) AS student_count FROM score GROUP BY subject; -- 分组字段必须出现在SELECT中(除聚合列外)
3. 与 HAVING 配合(分组后过滤)

WHERE过滤分组前的行,HAVING过滤分组后的聚合结果(不能用 WHERE 过滤聚合函数结果):

-- 找出平均分≥80的科目 SELECT subject, AVG(score) AS avg_score FROM score GROUP BY subject HAVING avg_score >= 80; -- 过滤分组后的聚合结果
4. 禁止与非聚合 / 非分组字段混用

SELECT 子句中,若包含聚合函数,其他字段必须是GROUP BY的分组字段,否则会报错(不同数据库严格度不同,如 MySQL 非严格模式可能返回随机值,需避免):

-- 错误示例:subject不是分组字段,也不是聚合函数 SELECT subject, AVG(score) FROM score; -- 正确示例:subject是分组字段 SELECT subject, AVG(score) FROM score GROUP BY subject;

三、常见注意事项

  1. 性能问题:聚合函数需遍历数据行,数据量极大时(百万 / 千万级),需给分组字段、过滤字段加索引优化;
  2. NULL 值处理:若需将 NULL 值计入计算(比如 NULL 视为 0),需用IFNULL()COALESCE()转换:
    -- 把NULL分数视为0,计算平均分 SELECT AVG(IFNULL(score, 0)) FROM score;
  3. 嵌套聚合:支持聚合函数嵌套(需用子查询),比如 “统计各科目平均分的最大值”:
    SELECT MAX(avg_score) FROM (SELECT AVG(score) AS avg_score FROM score GROUP BY subject) AS sub;

四、扩展:其他数据库特有聚合函数

  • PostgreSQLSTRING_AGG(列名, 分隔符)(类似 MySQL 的 GROUP_CONCAT)、PERCENTILE_CONT()(分位数计算);
  • SQL ServerSTRING_AGG(列名, 分隔符)COUNT_BIG()(统计大数行数,返回 bigint 类型);
  • OracleLISTAGG(列名, 分隔符) WITHIN GROUP (ORDER BY 列名)(分组拼接)、AVG()支持空值处理。

核心总结:聚合函数是 SQL 数据统计的核心工具,核心逻辑是 “对一组数据做汇总计算”,搭配GROUP BY/HAVING可实现精细化的分组统计,是数据分析、报表生成的基础。

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

每日一个C++知识点|面向对象之多态

C面向对象的三大特性是封装,继承,多态。上两篇文章分别讨论了封装和继承,今天主要是讲解C的另一个面向对象的特性~~多态 多态的概念 什么是多态呢? 多态的核心是"同一个接口,不同的实现" 简单来说,就是调用…

作者头像 李华
网站建设 2026/6/1 22:49:22

Open-AutoGLM实战手册:7个关键命令让你轻松掌控千万级进程流

第一章:Open-AutoGLM实战入门指南环境准备与依赖安装 在开始使用 Open-AutoGLM 之前,需确保本地已配置 Python 3.9 环境。推荐使用虚拟环境以隔离项目依赖。创建虚拟环境:python -m venv open-autoglm-env激活环境(Linux/macOS&am…

作者头像 李华
网站建设 2026/5/30 16:25:30

基于Java的幼儿园管理系统

摘 要 随着信息时代的来临,过去的传统管理方式缺点逐渐暴露,对过去的传统管理方式的缺点进行分析,采取计算机方式构建幼儿园管理系统。本文通过课题背景、课题目的及意义相关技术,提出了一种教 学生信息、学生考勤、健康记录、成长…

作者头像 李华
网站建设 2026/6/2 17:41:35

Open-AutoGLM定时任务配置实战(专家级配置方案曝光)

第一章:Open-AutoGLM定时任务配置概述Open-AutoGLM 是一款基于 AutoGLM 框架构建的自动化任务调度系统,专为大语言模型的周期性推理与数据处理任务设计。其核心功能之一是支持灵活的定时任务配置,使用户能够按需执行模型推理、结果上报与日志…

作者头像 李华
网站建设 2026/5/29 23:52:08

你真的会监控Open-AutoGLM吗?3个被忽视的关键指标必须掌握

第一章:你真的了解Open-AutoGLM的监控挑战吗在部署和运维 Open-AutoGLM 这类开源大语言模型自动化系统时,监控不仅是保障服务稳定的核心环节,更是发现潜在性能瓶颈与安全风险的关键手段。然而,许多团队在实践中低估了其复杂性&…

作者头像 李华
网站建设 2026/6/3 19:40:24

如何让Open-AutoGLM在服务器重启后自动恢复?关键配置详解

第一章:Open-AutoGLM 开机自动启动概述Open-AutoGLM 是一款基于 GLM 架构的开源自动化工具,专为系统级任务调度与服务自启设计。其核心功能之一是在操作系统启动时自动加载并运行指定服务,从而实现无人值守环境下的持续运作。该机制广泛应用于…

作者头像 李华