SQL聚合函数用于计算并返回单个值,包括COUNT、SUM、AVG、MIN、MAX和GROUP_CONCAT等;COUNT统计行数,可统计全表或非NULL值,支持DISTINCT去重;SUM计算数值列总和,自动忽略NULL值;聚合函数常与GROUP BY结合,按列分组后计算各组统计值,如平均分、总分等;使用时需注意NULL值处理、数据类型匹配及大数据量下的性能优化,可通过索引提升效率;例如统计各班及格人数可用COUNT结合CASE语句实现。

SQL的聚合函数,简单来说,就是对一组数据进行计算,最终返回一个单一值的函数。比如,你想知道某个班级有多少学生,或者所有学生的总分是多少,这时候聚合函数就派上用场了。
COUNT、SUM等函数的详解
除了COUNT和SUM,SQL还提供了很多其他的聚合函数,例如:
这些函数各有用途,可以根据实际需求灵活选择。
COUNT函数用于统计行数。它有两种常见的用法:
举个例子,假设我们有一个名为
students
id
name
age
-- 统计学生总数 SELECT COUNT(*) FROM students; -- 统计有多少学生有年龄信息(age列不为NULL) SELECT COUNT(age) FROM students;
注意,
COUNT(DISTINCT column_name)
SUM函数用于计算指定列的总和。它只能用于数值类型的列。
继续使用上面的
students
score
-- 计算所有学生的总成绩 SELECT SUM(score) FROM students;
如果
score
GROUP BY子句可以将表中的行按照一个或多个列的值进行分组。然后,我们可以对每个分组应用聚合函数,计算每个分组的统计信息。
例如,我们想统计每个年龄段的学生的平均成绩:
SELECT age, AVG(score) FROM students GROUP BY age;
这条SQL语句会先按照
age
COALESCE
举个实际的例子,假设我们需要统计每个班级的及格人数(假设及格分数是60分):
SELECT class_id, COUNT(CASE WHEN score >= 60 THEN 1 ELSE NULL END) AS passing_count FROM students GROUP BY class_id;
这个例子中,我们使用了
CASE
总之,SQL的聚合函数是非常强大的工具,可以帮助我们快速分析数据。掌握这些函数的用法,可以大大提高数据分析的效率。
以上就是什么是SQL的聚合函数?COUNT、SUM等函数的详解的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号