区别1
where是从数据表中的字段直接进行的筛选的。
having是从 前面筛选的字段再筛选
eg: select goods_price,goods_name from goods having goods_price > 100
等价于
select goods_price,goods_name from goods where goods_price > 100
select goods_name,goods_number from goods having goods_price > 100
// 报错!!!因为前面并没有筛选出 goods_price 字段
区别2
having子句中可以使用字段别名,而where不能使用
区别3
having能够使用统计函数,先分组,再判断(having),但是where不能使用
用的地方不一样
where可以用于select、update、delete和insert into values(select * from table where ..)语句中。
having只能用于select语句中
执行的顺序不一样
where的搜索条件是在执行语句进行分组之前应用
having的搜索条件是在分组条件后执行的
即如果where和having一起用时,where会先执行,having后执行
子句有区别
where子句中的条件表达式having都可以跟,而having子句中的有些表达式where不可以跟;having子句可以用集合函数(sum、count、avg、max和min),而where子句不可以。
总结
1.WHERE 子句用来筛选 FROM 子句中指定的操作所产生的行。
2.GROUP BY 子句用来分组 WHERE 子句的输出。
3.HAVING 子句用来从分组的结果中筛选行