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)
上一篇:Qt | 帮助手册学习


下一篇:mysql – 使用子查询重复数据删除