mysql - 当平均行大于某个数字时用mysql计算行的平均值

标签 mysql select average

我有一个计算行平均值的查询。单行的平均值由非空值组成。好吧,这行得通。 我现在想要的是仅在平均值大于某个数字时才计算该行。现在它正在使用所有行。 我怎样才能完成这项工作?

id | p_cijfer | b_cijfer | c_cijfer | c_id
----------------------------------------------
1  | 4        | 4        |    0     |   3   average = 4
----------------------------------------------
2  | 8        | 6        |    6     |   3   average = 6.7
----------------------------------------------
3  | 10       | 6        |    8     |   3   average = 8
----------------------------------------------
1  | 4        | 4        |    0     |   1   average = 4
----------------------------------------------

现在我只想计算平均值高于 6 的行的平均值。这将导致只计算记录 2 和 3。 输出必须是 id 的 2 和 3 的平均值,平均值 = (6.7+8)/2=7.5

select 

AVG(((reviews.prijs_cijfer+
 reviews.planning_cijfer+
 reviews.betrouwbaarheid_cijfer +
 reviews.communicatie_cijfer +
 reviews.kennis_cijfer +
 reviews.innovatie_cijfer
) /
nullif(
  case when prijs_cijfer=0 then 0 else 1 end +
  case when planning_cijfer=0 then 0 else 1 end +
  case when betrouwbaarheid_cijfer=0 then 0 else 1 end +
  case when communicatie_cijfer=0 then 0 else 1 end +
  case when kennis_cijfer=0 then 0 else 1 end +
  case when innovatie_cijfer=0 then 0 else 1 end , 0)))
from reviews

最佳答案

您可以使用子查询来应用过滤器。

select c_id, avg(rows.rowavg) filteredavg, count(rows.rowavg) affecting
from (
    select
        c_id c_id,
        ((reviews.prijs_cijfer+
        reviews.planning_cijfer+
        reviews.betrouwbaarheid_cijfer +
        reviews.communicatie_cijfer +
        reviews.kennis_cijfer +
        reviews.innovatie_cijfer
        ) /
        nullif(
        case when prijs_cijfer=0 then 0 else 1 end +
        case when planning_cijfer=0 then 0 else 1 end +
        case when betrouwbaarheid_cijfer=0 then 0 else 1 end +
        case when communicatie_cijfer=0 then 0 else 1 end +
        case when kennis_cijfer=0 then 0 else 1 end +
        case when innovatie_cijfer=0 then 0 else 1 end , 0)) rowavg
    from reviews
) rows
where rows.rowavg > 6
group by c_id

关于mysql - 当平均行大于某个数字时用mysql计算行的平均值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31078764/

相关文章:

mysql加载数据到文件系统锁定状态

mysql - 如何将 MySQL 5.5.40 升级到 MySQL 5.7

PHP - 关联表的爆炸结果查询

python - 根据其他列中的值平均某些列

colors - 如何将两个 32 位颜色平均打包成一个整数?

求平均值的C程序,代码有什么问题?

mysql - 查询 PostgreSQL 返回一个 NoneType

html - 是否可以在 html select 标签中设置希伯来语值?

MySQL 使用 select max (`Column` )+1 插入可能为空的结果

google-sheets - Google 表格查询函数 : Select Columns by Name