MySQL - 获得所有列平均值也具有“总”平均值

时间:2013-06-26 15:47:30

标签: mysql sql

我有一个MySQL表,如下所示:

id  load_transit    load_standby
1   40              20
2   30              15        
3   50              10

我需要做以下计算:

load_transit_mean = (40+30+50)/3 = 40
load_standby_mean = (20+15+10)/3 = 15
total_mean = (40+15)/2 = 27.5

是否可以在单个查询中执行此操作?最好的设计是什么?

我需要我的答案是可扩展的(真正的设计有更多的行和列),并且能够处理包含NULL的一些行。

1 个答案:

答案 0 :(得分:6)

我相信这样做会:

SELECT AVG(Load_transit)
     , AVG(load_standby)
     , (AVG(Load_transit) + AVG(load_standby))/2.0
FROM table

AVG()函数处理NULL,因为它忽略它们,如果你想在分母中计算NULL行,你可以AVG()替换SUM()而不是COUNT(*) ,即:

   SUM(load_transit)/COUNT(*)

关于可扩展性,如上所述手动列出它们可能是最简单的解决方案。