Sql Having条件语句

本文深入探讨了SQL中Having子句的应用,解释了其与Group By子句的配合使用,用于对分组后的数据进行过滤。并通过具体示例展示了如何统计特定条件下的部门员工数,以及如何结合聚合函数进行复杂的数据筛选。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值