AVG 函数
AVG 函数返回输入表达式值的平均值(算术平均值)。AVG 函数使用数值并忽略 NULL 值。
语法
AVG ( [ DISTINCT | ALL ] expression )
参数
- expression
-
对其执行函数的目标列或表达式。表达式为以下数据类型之一:
SMALLINT
INTEGER
BIGINT
NUMERIC
DECIMAL
REAL
DOUBLE PRECISON
SUPER
- DISTINCT | ALL
-
利用参数 DISTINCT,该函数可在计算平均值之前消除指定表达式中的所有重复值。利用参数 ALL,该函数可保留表达式中的所有重复值以计算平均值。ALL 是默认值。
数据类型
AVG 函数支持的参数类型为 SMALLINT、INTEGER、BIGINT、NUMERIC、DECIMAL、REAL、DOUBLE PRECISION 和 SUPER。
AVG 函数支持的返回类型为:
-
适用于任何整数类型参数的 BIGINT
-
适用于浮点型参数的 DOUBLE PRECISION
返回与任何其他参数类型的表达式相同的数据类型。
带有 NUMERIC 或 DECIMAL 参数的 AVG 函数结果的默认精度为 38。结果的小数位数与参数的小数位数相同。例如,DEC(5,2) 列的 AVG 返回 DEC(38,2) 数据类型。
示例
从 SALES 表中查找每笔交易所售的平均产品数:
select avg(qtysold)from sales; avg ----- 2 (1 row)
查找所有列表中列出的平均总价:
select avg(numtickets*priceperticket) as avg_total_price from listing; avg_total_price ----------------- 3034.41 (1 row)
查找平均支付价格 (以降序顺序按月分组):
select avg(pricepaid) as avg_price, month from sales, date where sales.dateid = date.dateid group by month order by avg_price desc; avg_price | month -----------+------- 659.34 | MAR 655.06 | APR 645.82 | JAN 643.10 | MAY 642.72 | JUN 642.37 | SEP 640.72 | OCT 640.57 | DEC 635.34 | JUL 635.24 | FEB 634.24 | NOV 632.78 | AUG (12 rows)