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 --从分组的结果中筛选行(分组之后过滤数据)
联系客服