今天看到园里一篇文章(http://www.cnblogs.com/sheldon-lou/p/4881230.html)中面试中有关sql 查询方面的问题,

想想自己从上大学就学习数据库,到后来自己也胡乱的写过一些小SQL,发现每次遇到问题,直接百度,然后Ctrl+C,Ctrl+V,

却也从来没有认真的去想过这个GRUOP BY和HAVING到底是怎么用,或是他们都有些什么用。说来惭愧的很。

创建表(自己瞎写的两个表):

CREATE TABLE    Department (
depID varchar(50) NOT NULL ,
depName varchar (50) NOT NULL
) CREATE TABLE Employee (
empID varchar (50) NOT NULL ,
empName varchar (50) NOT NULL ,
depID varchar (50) NOT NULL ,
empSex varchar (50) NULL ,
empAge int NULL
)

插入数据:

insert into Department(depID,depName) values('','技术部')
insert into Department(depID,depName) values('','流通部')
insert into Department(depID,depName) values('','采编部')
insert into Employee(empID,empName,depID,empSex,empAge) values('e0001','张三','','男',35)
insert into Employee(empID,empName,depID,empSex,empAge) values('e0002','李四','','男',30)
insert into Employee(empID,empName,depID,empSex,empAge) values('e0003','王五','','男',28)
insert into Employee(empID,empName,depID,empSex,empAge) values('e0004','清风','','女',32)
insert into Employee(empID,empName,depID,empSex,empAge) values('e0005','秋月','','女',30)
insert into Employee(empID,empName,depID,empSex,empAge) values('e0001','夏荷','','女',25)

多年的学校生活让我懒得不能再懒了,以下不少内容也是来自于网络,如有累同,勿怪。

1.     GROUP BY :group by将数据行分组,然后用聚组函数返回每一个组的汇总信息。

比如对于人员管理来说:我想查查各个部门多少人?

select a.depName,count(*) from Department a,Employee b
where a.depID=b.depID
group by a.depName

结果

003 采编部 2
001 技术部 2
002 流通部 2

这个是 依据(GROUP BY)部门名称(depName)来分组。

当然,如果这样的话是行不通的:

select a.depName,count(*) from Department a,Employee b
where a.depID=b.depID
group by a.depID 出现这样的错误:列 'a.depName' 在选择列表中无效,因为该列既不包含在聚合函数中,也不包含在 GROUP BY 子句中 所以:
在使用group by 时,有一个规则需要遵守,即出现在select列表中的字段,如果没有在组函数中,那么必须出现在group by 子句中。(select中的字段不可以单独出现,必须出现在group语句中或者在组函数中。)

还要注意一点:

当同时含有 where 子句、group by 子句 、having 子句及聚集函数时,执行顺序如下:

1.执行 where 子句查找符合条件的数据;
2.使用 group by 子句对数据进行分组;
3.对 group by 子句形成的组运行聚集函数计算每一组的值;
4.最后用 having 子句去掉不符合条件的组。

2.    HAVING:

  有人说"限制返回的结果集",但我更喜欢这个解释:"在分组之后过滤数据"
还是例子说话:
select a.depName,count(*) from Department a,Employee b
where a.depID=b.depID
group by a.depName
having a.depName like'采%'

结果也只有一条: 003 采编部 2

当然,如果我想查岁数大于30的如果呢?

select a.depName,count(*) from Department a,Employee b
where a.depID=b.depID
group by a.depName
having b.empAge>30

这个显然是行不通的:

1.分完组后,里面是没有empAge这个字段的,故也不可能按此字段过滤数据。

2.前面提到了,先查数据,再分组,最后过滤。

其实我最想说的是下面这段话(不是我说的):

where:      在分组前进行过滤数据;

group by:  在分组前查询后,先排序再分组;

having:      在分组后进行过滤数据。

      

关于sql 中 group by 和 having的更多相关文章

  1. MYSQL:SQL中Group By的使用

    SQL中Group By的使用   1.概述 2.原始表 3.简单Group By 4.Group By 和 Order By 5.Group By中Select指定的字段限制 6.Group By ...

  2. 转载:SQL中Group By 的常见使用方法

    SQL中Group By 的常见使用方法  转载源:http://www.cnblogs.com/wang-meng/p/5373057.html 前言今天逛java吧看到了一个面试题, 于是有了今天 ...

  3. sql中group by用来干嘛的

    sql中group by用来干嘛的 一.总结 一句话总结: 1.group by用来分类汇总的,by后面接要分的类 2.group by既然是分类汇总,那就要和聚合函数结合使用,因为要汇总啊 3.ha ...

  4. sql中group by 和having 用法解析

    --sql中的group by 用法解析:-- Group By语句从英文的字面意义上理解就是“根据(by)一定的规则进行分组(Group)”.--它的作用是通过一定的规则将一个数据集划分成若干个小的 ...

  5. sql中group by

    某图书馆收藏有书籍具有不同的出版年份,管理员需要做一下统计工作: (1)每一年书籍的数目,如: 2000年有10本书, 2001年有5本书... (2)每一种书籍的数目,如: 西游记有10本, 三国演 ...

  6. SQL中group by后面的having中不能使用别名

    如下图中,SQL中需要对group by的结果使用having进行过滤,不能使用select中定义的别名,需要使用查询字段的原始名.否则会报错,列明未定义. 下图未错误演示: 修改后,正确的SQL语句 ...

  7. SQL中Group By的使用

    1.概述 2.原始表 3.简单Group By 4.Group By 和 Order By 5.Group By中Select指定的字段限制 6.Group By All 7.Group By与聚合函 ...

  8. SQL中Group By 的使用

    1.概述 “Group By”从字面意义上理解就是根据“By”指定的规则对数据进行分组,所谓的分组就是将一个“数据集”划分成若干个“小区域”,然后针对若干个“小区域”进行数据处理. 2.原始表 3.简 ...

  9. [数据库]SQL中Group By 的常见使用方法.

    前言今天逛java吧看到了一个面试题, 于是有了今天这个文章, 回顾下Group By的用法.题目如下:Select name from table group by name having coun ...

  10. 【转】SQL中Group By的使用

    1.概述 2.原始表 3.简单Group By 4.Group By 和 Order By 5.Group By中Select指定的字段限制 6.Group By All 7.Group By与聚合函 ...

随机推荐

  1. 实验记录一 初步接触cortex-M3

    应该说老早就在接触cortex-M3了.曾经没想到会接触嵌入式,结果由于导师的缘故.在选择项目管理时,就呵呵了.不废话.搭配环境非常easy,纯粹傻瓜式.可由于自己的马虎,却让自己一直困惑. 记得在前 ...

  2. 理解Android的layout和measure

    在Android UI开发中,总会有情况需要自定义View和View Group. 什么是View?就是Android中一个基本视图单位,一个Button是一个view, 一个Layout, 也是一个 ...

  3. Google Maps 学习笔记(二)地图天气预报服务 2014.06.04

    地图天气预报服务:一,获取天气预报信息:二,解析天气预报信息:三,在地图上加载天气预报信息: Yahoo!提供的天气预报服务采用流行的RSS输出结果,接口地址如下: http://weather.ya ...

  4. 【转】sqlserver数据库之间的表的复制

    以下以数据库t1和test为例.  1.复制表结构及资料 select * into 数据库名.dbo.表名 from 源表(全部数据)     如:select * into t1.dbo.YS1 ...

  5. Unable to locate appropriate constructor on class异常

    一般出现Unable to locate appropriate constructor on class这个异常,都是实体类的带参数的构造方法和使用查询语句出现偏差,两个地方的代码如下: 一般都是第 ...

  6. [Swust OJ 385]--自动写诗

    题目链接:http://acm.swust.edu.cn/problem/0385/ Time limit(ms): 5000 Memory limit(kb): 65535    Descripti ...

  7. 解决IDAPython: importing "site" failed.的问题

    当我打开IDA6.8时候,里面报Warning, IDAPython: importing "site" failed. WTF!? 我点了OK后,进去发现IDA底部的python ...

  8. 利用python进行数据分析之pandas库的应用(一)

    一.pandas的数据结构介绍 Series Series是由一种类似于一维数组的对象,它由一组数据以及一组与之相关的数据索引构成.仅由一组数据可产生最简单的Series. obj=Series([4 ...

  9. Latex调整行距

    修改行间距的方法: \usepackage{setspace}%使用间距宏包 \begin{document} \begin{spacing}{2.0}%%行间距变为double-space 双倍行距 ...

  10. java.lang.VerifyError: Inconsistent stackmap frames at branch target

    -XX:-UseSplitVerifier解决. 附带网址:http://stackoverflow.com/questions/12774672/java-7-inconsistent-stackm ...