Where和Having的区别
面试时先将定义阐述清楚
Where:过滤,分组前的过滤,Where是对数字源进行过滤
having:过滤,分组后的过滤
类型:
“Where”是一个约束声明,在查询数据库的结果返回之前对数据库中的查询条件进行约束,即在结果返回之前起作用,且where后面不能使用“聚合函数”;
“Having”是一个过滤声明,所谓过滤是在查询数据库的结果返回之后进行过滤,即在结果返回之后起作用,并且having后面可以使用“聚合函数”。
使用的角度:
where后面之所以不能使用聚合函数是因为where的执行顺序在聚合函数之前。