首页 > 代码库 > mysql where 和 having 的区别
mysql where 和 having 的区别
作用的对象不同。WHERE 子句作用于表和视图,HAVING 子句作用于组。
where 是对表的筛选,而having是对聚合结果的筛选。
有时候having和where都可以达到同样的结果,但是要优先使用where。
WHERE 在分组和聚集计算之前选取输入行(因此,它控制哪些行进入聚集计算), 而 HAVING 在分组和聚集之后选取分组的行。因此,WHERE 子句不能包含聚集函数; 因为试图用聚集函数判断那些行输入给聚集运算是没有意义的。 相反,HAVING 子句总是包含聚集函数。(严格说来,你可以写不使用聚集的 HAVING 子句, 但这样做只是白费劲。同样的条件可以更有效地用于 WHERE 阶段。)
having一般跟在group by之后,执行记录组选择的一部分来工作的。
where则是执行所有数据来工作的。
再者having可以用聚合函数,如having sum(qty)>1000
本文出自 “程序猿的那些年” 博客,请务必保留此出处http://uyuyuuy.blog.51cto.com/6190986/1544140
mysql where 和 having 的区别
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。