MySQL中where与having区别

其实功能上WHERE和HAVING并无区别,都是做查询过滤。但是效率以及执行顺序并不一样。一般来说,where跟在from后,having跟在group by后,但不要错误的认为having和group by必须配合使用

从整体声明的角度来理解:

     “Where”是一个约束声明,在查询数据库的结果返回之前对数据库中的查询条件进行约束,即在结果返回之前起作用,且where后面不能使用“聚合函数”

       “Having”是一个过滤声明,所谓过滤是在查询数据库的结果返回之后进行过滤,即在结果返回之后起作用,并且having后面可以使用“聚合函数”

从使用的角度来理解:

where后面之所以不能使用聚合函数是因为where的执行顺序在聚合函数之前。

       having既然是对查出来的结果进行过滤,那么就不能对没有查出来的值使用having

从作用主体来理解

       where是针对数据库文件发挥作用,而having是针对结果集发挥作用:

              where后面要跟的是数据表里的字段,where针对数据库文件(比如表)发挥作用。

              而having只是根据前面查询出来的结果集再次进行查询,因此having是针对结果集发挥作用。

借鉴:

https://www.jianshu.com/p/e23fb6704166

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值