mysql 设置计算列_mysql – 创建计算列

我想创建一个评级权重,我需要计算AVG,然后找到COUNT并乘以两者来获得权重.我有类似的东西:

SELECT post_id, COUNT(CASE WHEN vote > 0 THEN vote ELSE NULL END) AS voters,

AVG(CASE WHEN vote > 0 THEN vote ELSE NULL END) AS average FROM wp_imdb_rating

GROUP BY post_id

ORDER BY voters * average DESC

LIMIT 0, 100

但它说:

#1247 – Reference ‘voters’ not supported (reference to group function)

我可以分别按平均和选民的顺序排序,但我不能将它们与任何公式结合起来.如何在包含AVG和COUNT值的order子句中使用公式?

谢谢.

解决方法:

它似乎是优化器的一些旧限制,ORDER BY中更复杂的表达式中不允许使用聚合表达式的别名.

您可以使用完整表达式而不是别名来解决它:

ORDER BY

COUNT(CASE WHEN vote > 0 THEN vote ELSE NULL END)

*

AVG(CASE WHEN vote > 0 THEN vote ELSE NULL END)

标签:mysql,count,functions

来源: https://codeday.me/bug/20190806/1604746.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值