- where 是一个约束声明
在查询数据库的结果返回之前对数据库中的查询条件进行约束,即在结果返回之前起作用,且where后面不能使用 “聚合函数”
- having 是一个过滤声明
所谓过滤是在查询数据库的结果返回之后进行过滤,即在结果返回之后起作用,并且having后面可以使用“聚合函数”
- 使用角度:where之所以不能使用聚合函数是因为where的执行顺序在聚合函数之前
select * from user where avg(age) >18 #错误示范
在查询数据库的结果返回之前对数据库中的查询条件进行约束,即在结果返回之前起作用,且where后面不能使用 “聚合函数”
所谓过滤是在查询数据库的结果返回之后进行过滤,即在结果返回之后起作用,并且having后面可以使用“聚合函数”
select * from user where avg(age) >18 #错误示范