TT在努力 2022-11-06 12:03 采纳率: 82.4%
浏览 13
已结题

聚合case when之后的字段

count(
case
when result = 'right' then 1
else null
end
) / count(q2.question_id) as rightrate
这样可以跑出结果,但是我命名了条件分支的字段
count(
case
when result = 'right' then 1
else null
end as right_cnt
) / count(q2.question_id) as rightrate
这样就不行了
就是count right_cnt 这个字段

  • 写回答

1条回答 默认 最新

  • 程序媛一枚~ Python领域新星创作者 2022-11-06 13:03
    关注

    别名得放在外边,如果你想既要count,又要比率的话这样

    count(
    case
    when result = 'right' then 1
    else null
    end
    )  as right_cnt,
    count(
    case
    when result = 'right' then 1
    else null
    end
    ) / count(q2.question_id) as rightrate
    

    计数的话我觉得case when不成立的else 为0比较好呢
    count(
    case
    when result = 'right' then 1
    else 0
    end
    ) as right_cnt,

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 11月15日
  • 已采纳回答 11月7日
  • 创建了问题 11月6日

悬赏问题

  • ¥15 我这模型写的不对吗?为什么lingo解出来的下面影子价格这一溜少一个变量
  • ¥50 树莓派安卓APK系统签名
  • ¥15 maple软件,用solve求反函数出现rootof,怎么办?
  • ¥65 汇编语言除法溢出问题
  • ¥15 Visual Studio问题
  • ¥20 求一个html代码,有偿
  • ¥100 关于使用MATLAB中copularnd函数的问题
  • ¥20 在虚拟机的pycharm上
  • ¥15 jupyterthemes 设置完毕后没有效果
  • ¥15 matlab图像高斯低通滤波