如何在一行中选择多列的AVG

时间:2010-11-24 15:58:49

标签: sql mysql

如何选择多列的平均值?

假设我有一些数据:

X   Y    Z
-------------
6   3    3
5   5    NULL
4   5    6
11  7    8

我希望得到像

这样的东西
AVG
-------------
4
5
5
8.66666667

我尝试了select avg(x, y, z) from table

但它不起作用。

有关查询的任何想法吗?

3 个答案:

答案 0 :(得分:10)

尝试

 Select     (Coalesce(x,0) + Coalesce(y,0) + Coalesce(z,0)) /
       (Coalesce(x/x, 0) + Coalesce(y/y, 0) + Coalesce(z/z, 0))

 Select (Coalesce(x,0) + Coalesce(y,0) + Coalesce(z,0)) /
         (Case When x Is Null 0 Else 1 End +
          Case When y Is Null 0 Else 1 End +
          Case When z Is Null 0 Else 1 End)

答案 1 :(得分:3)

您将它们相加,然后除以值的数量。从平均操作的分母中排除NULL有点棘手:

SELECT (IFNULL(x, 0) + IFNULL(y, 0) + IFNULL(z, 0)) /
       (IIF(ISNULL(x), 0, 1) + IIF(ISNULL(y), 0, 1) + IIF(ISNULL(z), 0, 1))
  FROM YourTable

答案 2 :(得分:1)

尝试:

(x + y + z) / 3