如何选择多列的平均值?
假设我有一些数据:
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
但它不起作用。
有关查询的任何想法吗?
答案 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