如何运用 SQL 的 SUM() 和 AVG() 函数在财务报表中快速计算总金额及平均数?
- 内容介绍
- 相关推荐
本文共计674个文字,预计阅读时间需要3分钟。
在财务报表分析中,SUM()和AVG()是最常用的聚合函数,分别用于计算某项金额的总和与平均值。SUM()用于计算总和,AVG()用于计算平均值。关键在于明确计算对象(如收入、成本、利润等)、注意空值(NULL)处理,并结合分组(GROUP BY)或筛选(WHERE)满足实际业务需求。
一、基础用法:单列求和与平均
假设有一张 financial_data 表,包含字段:month(月份)、revenue(营业收入)、expense(营业支出):
- SUM(revenue) 返回全部记录的营收总和;
- AVG(expense) 返回所有非 NULL 支出值的算术平均(自动忽略 NULL);
- 若某月 expense 为 NULL,它不参与 AVG 计算,也不影响分母(即只按有值的行数计)。
二、按时间或类别分组统计
财务报表常需按季度、部门或产品线汇总。使用 GROUP BY 配合 SUM/AVG:
-
SELECT QUARTER(month) AS qtr, SUM(revenue) AS total_revenue FROM financial_data GROUP BY qtr;→ 计算每季度营收总额; -
SELECT dept, AVG(profit) FROM sales_detail GROUP BY dept HAVING AVG(profit) > 10000;→ 筛出平均利润超 1 万元的部门(HAVING 用于过滤分组后结果)。
三、带条件的聚合:WHERE 与 CASE WHEN
不是所有数据都应纳入计算。常用方式包括:
- 用 WHERE 预过滤:例如
WHERE month BETWEEN '2023-01' AND '2023-12'限定年度范围; - 用 CASE WHEN 实现条件聚合:如计算“仅销售部的平均毛利率”,可写:
AVG(CASE WHEN dept = 'Sales' THEN gross_margin END)—— 此写法自动跳过非销售部记录(返回 NULL),不影响 AVG 分母。
四、注意事项与常见陷阱
-
NULL 值不参与计算,但也不会报错;若需把 NULL 当 0 处理,用
COALESCE(revenue, 0)包裹后再 SUM; -
AVG 对整数列可能截断小数:如 AVG(1,2,3) 在某些数据库中返回 2(而非 2.0),建议显式转换类型,如
AVG(CAST(revenue AS DECIMAL(10,2))); - 避免在 SELECT 中混用聚合与非聚合字段(除非该字段在 GROUP BY 中),否则会报错或结果不可靠。
本文共计674个文字,预计阅读时间需要3分钟。
在财务报表分析中,SUM()和AVG()是最常用的聚合函数,分别用于计算某项金额的总和与平均值。SUM()用于计算总和,AVG()用于计算平均值。关键在于明确计算对象(如收入、成本、利润等)、注意空值(NULL)处理,并结合分组(GROUP BY)或筛选(WHERE)满足实际业务需求。
一、基础用法:单列求和与平均
假设有一张 financial_data 表,包含字段:month(月份)、revenue(营业收入)、expense(营业支出):
- SUM(revenue) 返回全部记录的营收总和;
- AVG(expense) 返回所有非 NULL 支出值的算术平均(自动忽略 NULL);
- 若某月 expense 为 NULL,它不参与 AVG 计算,也不影响分母(即只按有值的行数计)。
二、按时间或类别分组统计
财务报表常需按季度、部门或产品线汇总。使用 GROUP BY 配合 SUM/AVG:
-
SELECT QUARTER(month) AS qtr, SUM(revenue) AS total_revenue FROM financial_data GROUP BY qtr;→ 计算每季度营收总额; -
SELECT dept, AVG(profit) FROM sales_detail GROUP BY dept HAVING AVG(profit) > 10000;→ 筛出平均利润超 1 万元的部门(HAVING 用于过滤分组后结果)。
三、带条件的聚合:WHERE 与 CASE WHEN
不是所有数据都应纳入计算。常用方式包括:
- 用 WHERE 预过滤:例如
WHERE month BETWEEN '2023-01' AND '2023-12'限定年度范围; - 用 CASE WHEN 实现条件聚合:如计算“仅销售部的平均毛利率”,可写:
AVG(CASE WHEN dept = 'Sales' THEN gross_margin END)—— 此写法自动跳过非销售部记录(返回 NULL),不影响 AVG 分母。
四、注意事项与常见陷阱
-
NULL 值不参与计算,但也不会报错;若需把 NULL 当 0 处理,用
COALESCE(revenue, 0)包裹后再 SUM; -
AVG 对整数列可能截断小数:如 AVG(1,2,3) 在某些数据库中返回 2(而非 2.0),建议显式转换类型,如
AVG(CAST(revenue AS DECIMAL(10,2))); - 避免在 SELECT 中混用聚合与非聚合字段(除非该字段在 GROUP BY 中),否则会报错或结果不可靠。

