mysql where为什么不能使用别名_您能在MySQL的WHERE子句中使用别名吗?

d4a349cc0702438ab3dfdb4a67510125.png

波斯汪

这个问题很老了,一个答案已经得到一百六十票.但我还是要说清楚:问题是不属性中是否可以使用别名。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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值