Where和Having的区别

Posted 小小小虎

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Where和Having的区别相关的知识,希望对你有一定的参考价值。

面试时先将定义阐述清楚

Where:过滤,分组前的过滤,Where是对数字源进行过滤

having:过滤,分组后的过滤

 

类型:

 

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

 

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

 

使用的角度:

 

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

以上是关于Where和Having的区别的主要内容,如果未能解决你的问题,请参考以下文章

SQL中的HAVING和WHERE有啥区别?

having和where的区别

GROUP BY,WHERE,HAVING之间的区别和用法

GROUP BY,WHERE,HAVING之间的区别和用法

数据库中having 和where有啥区别

一文让你彻底理解having和where的区别