啰嗦点:

where子句用来筛选 from子句中指定的操作所产生的行。

group by 子句用来分组 where子句的输出。

having子句用来从分组的结果中筛选行。

对于可以在分组操作之前或之后应用的任何搜索条件,在 where子句中指定它们会更有效。这样可以减少必须分组的行数。应当在 having子句中指定的搜索条件只是那些必须在执行分组操作之后应用的搜索条件。

简单点:

select ··· from ···

where ···(只能对分组前的属性进行筛选)

group by ···

having ···(只能对分组后的每个组的整体属性进行筛选,用聚合函数体现)

以上四个命令是从大到小依次进行过滤

举个栗子:

我们如果就是查询每个部门成绩大于89的员工数,可以这样写:

SELECT dept,count(name) FROM user WHERE score>89 GROUP BY dept;

 上面用到where是在分组前限制,如何用having呢? 上面的基础上再加一个条件,查询部门人数大于1的部门。

那么我们是先要统计出每个部门的人数,也就是要用count聚合函数,然后再看哪些部门的人数是多于1人的

也就是筛选条件是在聚合之后的,这时where已不能满足使用,我们就需要用到having了

SELECT dept,count(name) nums FROM user GROUP BY dept HAVING nums >1;

  

注:

having后面跟的条件判断的字段必须是聚合函数返回的结果,否则sql会报错,例如:

SELECT dept,count(name) nums FROM user GROUP BY dept HAVING score >1;

参考:

https://blog.csdn.net/u013182960/article/details/80819505

http://www.cnblogs.com/doudouxiaoye/p/5798623.html

https://blog.csdn.net/qq_24556707/article/details/79552324

随机推荐

  1. 关于 iOS 性能优化方面的面试题,

    这是我前面几天碰到的面试题: 如何对定位和分析项目中影响性能的地方?以及如何进行性能优化? 我的答案: 定位方法: instruments   在iOS上进行性能分析的时候,首先考虑借助instrum ...

  2. Alertmanager 集群

    Alertmanager 集群搭建 环境准备:2台主机 (centos 7) 192.168.31.151 192.168.31.144 1.安装部署 192.168.31.151 cd /usr/l ...

  3. current account(经常账户)

    python信用评分卡(附代码,博主录制) https://study.163.com/course/introduction.htm?courseId=1005214003&utm_camp ...

  4. TF用法指导

    一.变量 1 .tf.Variables() 功能:创建变量 2.tf.get_variable() 功能:创建变量,注意和上面的区别 3.tf.variable_scope() 功能:其实只要记住一 ...

  5. MYCP作业

    本次作业主要复习了输入流输出流的内容 作业要求: 编写MyCP.java 实现类似Linux下cp XXX1 XXX2的功能,要求MyCP支持两个参数: java MyCP -tx XXX1.txt ...

  6. ES2015 中的函数式Mixin

    原文链接:http://raganwald.com/2015/06/17/functional-mixins.html 在“原型即对象”中,我们看到可以对原型使用 Object.assign 来模拟 ...

  7. 【C++笔记】explicit 指定符

    用于抑制构造函数的自动隐式转换. struct A { A(int) { } // 转换构造函数 A(int, int) { } // 转换构造函数 (C++11) operator bool() c ...

  8. linux mint18 cinnamon 64bit 安装 docker

    参考官方文档:https://docs.docker.com/engine/installation/linux/ubuntu/ 1. 安装一些使 apt 可以使用 https 的源 sudo apt ...

  9. P5283 [十二省联考2019]异或粽子

    考场上想到了没打完,细节思路还是不是很优,我原先的想法是每一次找完后标记那个点,下次再继续找(并不是这个意思,说不清楚)但实际上和平衡树一样加个大小就很好写了 #include<bits/std ...

  10. java Socket实例

    可以实现客户端与服务端双向通信,支持多客户端连接,客户端断开连接,服务端不会出现异常 服务端代码: package com.thinkgem.jeesite.modules.socketTest.de ...