今天看到园里一篇文章(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. IOS框架概览

    iOS是执行在iPhone.iPod Touch或iPad上的操作系统,之前叫做iPhone OS,iOS与Mac OS X有共同的基础架构和底层技术.但iOS是依据移动设备的特点而设计的,所以和Ma ...

  2. iOS面试题04-runtime

    runtime/KVO等面试题 1.KVO内部实现原则 回答:1>KVO是基于runtime机制实现的 2>当某个类的对象第一次被观察时,系统就会在运行期动态地创建该类的一个派生类,在这个 ...

  3. result 相关

    1.dispatcher 2.redirect 3.chain 4.redirectAction 5.freemarker 6.httpheader 7.stream 8.velocity 9.xsl ...

  4. AsyncSocket 使用

    今天使用AsyncSocket模拟及时通信,在这里记录一下,免得以后自己又犯相同的错误 1>创建客户端和服务器socket /** * 设置socket */ - (void)setupSock ...

  5. 原生js实现的轮播图,易用+可多用

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...

  6. load_library(linker.cpp:759): library "libmaliinstr.so" not found

    1.02-07 15:19:09.277: E/linker(16043): load_library(linker.cpp:759): library "libmaliinstr.so&q ...

  7. 怪兽z主机标准版视频测试。

    我的淘宝店很早就开张了,但是一直没有好好打理,这次给大家带来的是本店所售一款主机的视频测试. CPU:AMD -A10 6700 主板:映泰Hi-Fi A88S3E 内存条:正品金士顿骇客游戏神条 机 ...

  8. qt example

    #include"mainwindow.h" #include"ui_mainwindow.h" #include<QWebFrame> #incl ...

  9. hdu1711(终于搞懂了KMP算法了。。)

    题意:给你两个长度分别为n(1 <= N <= 1000000)和m(1 <= M <= 10000)的序列a[]和b[],求b[]序列在a[]序列中出现的首位置.如果没有请输 ...

  10. [cocos2d-x]用CCSpriteBatchNode进行文理贴图的优化

    引言: 我们在进行手机游戏开发的过程中,由于手机的内存资源是有限的,那么对纹理贴图的优化是非常有必要的,有可能相同的功能,优化的好与不好对内存资源的消耗是非常明显的,下面我就用一个例子来说明一下. 说 ...