波斯汪
这个问题很老了,一个答案已经得到一百六十票.但我还是要说清楚:问题是不属性中是否可以使用别名。WHERE条款。sum(reviews.rev_rating) / count(reviews.rev_id) as avg_rating是一个聚合。在WHERE子句,我们通过查看表的值来限制我们希望从表中获得的记录。sum(reviews.rev_rating)和count(reviews.rev_id)然而,不是我们在记录中找到的值;它们是我们只有在聚合记录之后才能得到的值。所以WHERE是不合适的。我们需要HAVING,因为我们希望在聚合之后限制结果行。不可能WHERE avg_rating > 10也不WHERE sum(reviews.rev_rating) / count(reviews.rev_id) > 10因此。HAVING sum(reviews.rev_rating) / count(reviews.rev_id) > 10另一方面,它是可能的,并且符合SQL标准。鉴于HAVING avg_rating > 10只有在MySQL中才有可能。根据标准,它不是有效的sql,因为SELECT子句应该在HAVING..来自MySQL文档:对标准SQL的另一个MySQL扩展允许在HAVING子句中引用SELECT列表中的别名表达式。MySQL扩展允许在聚合列的HANING子句中使用别名。https:/dev.mysql.com/doc/refman/5.7/en/group-by handling.html