打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
SqlHaving条件语句
userphoto

2023.05.06 甘肃

关注

1.Having子句是SELECT语句的可选子句。它用于过滤由 group by 子句返回的行分组。 

一般用法:having一般和group by联合使用,通常用在聚合函数前面,对分组后的数据进行过滤,(MAX、MIN、COUNT、SUM等)

2.举个例子:

  1. --统计员工人数大于300的部门?
  2. select
  3. deptName,
  4. count(deptName)
  5. from
  6. user
  7. having
  8. count(deptName) > 300
  1. --统计员工人数大于300并且平均年龄在20到25岁之间的部门
  2. SELECT
  3. deptName,
  4. count(deptName) deptNum,
  5. avg(age) ageAvg
  6. FROM
  7. user
  8. GROUP BY
  9. deptName
  10. HAVING
  11. count(deptName) > 300 AND
  12. avg(age) BETWEEN 20 AND 25
  13. ORDER BY
  14. 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 --从分组的结果中筛选行(分组之后过滤数据)

 

 

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
简单的SQL语句学习资料 经典SQL语句
sql语句中GROUP BY 和 HAVING的使用 count()_ZF_Favorit...
SQL语句汇总(三)
一道SQL问题:找出成绩优秀的学生
SQL简单查询
数据查询1之简单查询
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服