Sql Having条件语句

    技术2022-07-12  74

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

     

    Processed: 0.015, SQL: 10