1.Having子句是SELECT语句的可选子句。它用于过滤由 group by 子句返回的行分组。
一般用法:having一般和group by联合使用,通常用在聚合函数前面,对分组后的数据进行过滤,(MAX、MIN、COUNT、SUM等)
2.举个例子:
--统计员工人数大于300的部门? select deptName, count(deptName) from user having count(deptName) > 300 --统计员工人数大于300并且平均年龄在20到25岁之间的部门 SELECT deptName, count(deptName) deptNum, avg(age) ageAvg FROM user GROUP BY deptName HAVING count(deptName) > 300 AND avg(age) BETWEEN 20 AND 25 ORDER BY deptName DESC;ps:
1、group by能单独使用,那having能排除group by 单独使用吗?
一般情况下是不能单独使用的。既然是一般,那肯定有特殊情况了,如下
select 1 from user having count(dept) >= 1;select 后面 不能是表字段,所以意义不是很大,算是特殊用法吧。
2、having和where都能过滤,那和where的有哪些不同?能和where一起使用吗?
where后面不能与聚合函数一起使用,所以用having来实现。having是能和where一起使用的。如下
select xx from where --筛选FROM子句中指定的操作所产生的行(分组之前过滤数据) group by --分组WHERE子句 having --从分组的结果中筛选行(分组之后过滤数据)