我想创建一个评级权重,我需要计算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)