news 2026/2/8 14:36:24

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/2/8 7:48:15

用Linly-Talker做科普?NASA风格太空讲解视频生成实录

用Linly-Talker做科普?NASA风格太空讲解视频生成实录 在公众对宇宙探索的热情持续高涨的今天,如何让复杂的天体物理知识变得通俗易懂,成了科学传播者的一道难题。传统科普视频制作周期长、成本高,往往需要专业摄像、配音和后期团队…

作者头像 李华
网站建设 2026/2/8 9:59:11

揭秘Open-AutoGLM开机启动机制:5步完成无人值守自动化部署

第一章:Open-AutoGLM开机启动机制概述Open-AutoGLM 是一款基于大语言模型的自动化系统工具,其核心功能之一是实现服务在操作系统启动时自动加载与运行。该机制确保模型推理服务、任务调度模块及API接口能够在系统重启后无需人工干预即可恢复运行&#xf…

作者头像 李华
网站建设 2026/2/7 2:54:22

【专家级排错前置技能】:Open-AutoGLM运行日志开启的4步黄金法则

第一章:Open-AutoGLM运行日志开启的核心价值开启运行日志是保障 Open-AutoGLM 系统可观测性与可维护性的关键步骤。通过详细记录模型推理、任务调度及系统交互过程中的关键事件,日志为性能调优、故障排查和安全审计提供了坚实的数据基础。提升系统透明度…

作者头像 李华
网站建设 2026/2/4 8:04:13

Linly-Talker支持语音克隆,打造个性化虚拟形象

Linly-Talker:用语音克隆打造你的专属数字人 在直播带货的深夜,一位“主播”依然精神饱满地讲解着商品特性,声音亲切熟悉;在在线课堂中,一段由教师本人音色讲述的课程视频自动循环播放;甚至在家庭相册里&am…

作者头像 李华
网站建设 2026/2/7 17:50:28

Linly-Talker在梯田耕作系统中的水土保持讲解

Linly-Talker:用AI数字人讲好梯田水土保持的故事 在云南红河的清晨,薄雾还未散尽,层层叠叠的哈尼梯田已经泛起粼粼波光。这片延续千年的农耕智慧,正面临现代生态挑战——如何防止雨水冲刷带走宝贵的土壤?传统的科普方式…

作者头像 李华