簡體   English   中英

如何在一行中選擇多列的AVG

[英]how do I select AVG of multiple columns on a single row

如何選擇多列的平均值?

假設我有一些數據,如:

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

但它不起作用。

有關查詢的任何想法嗎?

嘗試

 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)

您將它們相加,然后除以值的數量。 從平均操作的分母中排除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

嘗試:

(x + y + z) / 3

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM