关于sql 中 group by 和 having
今天看到园里一篇文章(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的更多相关文章
- MYSQL:SQL中Group By的使用
SQL中Group By的使用 1.概述 2.原始表 3.简单Group By 4.Group By 和 Order By 5.Group By中Select指定的字段限制 6.Group By ...
- 转载:SQL中Group By 的常见使用方法
SQL中Group By 的常见使用方法 转载源:http://www.cnblogs.com/wang-meng/p/5373057.html 前言今天逛java吧看到了一个面试题, 于是有了今天 ...
- sql中group by用来干嘛的
sql中group by用来干嘛的 一.总结 一句话总结: 1.group by用来分类汇总的,by后面接要分的类 2.group by既然是分类汇总,那就要和聚合函数结合使用,因为要汇总啊 3.ha ...
- sql中group by 和having 用法解析
--sql中的group by 用法解析:-- Group By语句从英文的字面意义上理解就是“根据(by)一定的规则进行分组(Group)”.--它的作用是通过一定的规则将一个数据集划分成若干个小的 ...
- sql中group by
某图书馆收藏有书籍具有不同的出版年份,管理员需要做一下统计工作: (1)每一年书籍的数目,如: 2000年有10本书, 2001年有5本书... (2)每一种书籍的数目,如: 西游记有10本, 三国演 ...
- SQL中group by后面的having中不能使用别名
如下图中,SQL中需要对group by的结果使用having进行过滤,不能使用select中定义的别名,需要使用查询字段的原始名.否则会报错,列明未定义. 下图未错误演示: 修改后,正确的SQL语句 ...
- SQL中Group By的使用
1.概述 2.原始表 3.简单Group By 4.Group By 和 Order By 5.Group By中Select指定的字段限制 6.Group By All 7.Group By与聚合函 ...
- SQL中Group By 的使用
1.概述 “Group By”从字面意义上理解就是根据“By”指定的规则对数据进行分组,所谓的分组就是将一个“数据集”划分成若干个“小区域”,然后针对若干个“小区域”进行数据处理. 2.原始表 3.简 ...
- [数据库]SQL中Group By 的常见使用方法.
前言今天逛java吧看到了一个面试题, 于是有了今天这个文章, 回顾下Group By的用法.题目如下:Select name from table group by name having coun ...
- 【转】SQL中Group By的使用
1.概述 2.原始表 3.简单Group By 4.Group By 和 Order By 5.Group By中Select指定的字段限制 6.Group By All 7.Group By与聚合函 ...
随机推荐
- android UI进阶之用【转】
android UI进阶之用ViewPager实现欢迎引导页面 摘要: ViewPager需要android-support-v4.jar这个包的支持,来自google提供的一个附加包.大家搜下即可. ...
- Android仿人人客户端(v5.7.1)——个人主页(三)
转载请标明出处:http://blog.csdn.net/android_ls/article/details/9405089 声明:仿人人项目,所用所有图片资源都来源于其它Android移动应用,编 ...
- gdb篇
转自:http://www.cnblogs.com/ypchenry/p/3668572.html 1.gdb的原理 熟悉linux的同学面试官会问你用过gdb么?那好用过,知道gdb是怎么工作的么? ...
- git 使用笔记(三)-分支的使用
简单介绍 之前说过,每次修改之后,Git 并不是保存这些修改之后的差异变化,实际上就像一个照相机一样,将修改后的文件拍下作为文件快照,记录在一个微型的文件系统中.在 Git 中提交时,会保存一个提交对 ...
- js调试若干
主要是将 chrome调试工具 firebug的控制台对以下都有支持 consoleAPI https://developers.google.com/chrome-developer-tools ...
- Android应用开发提高篇(1)-----获取本地IP
链接地址:http://www.cnblogs.com/lknlfy/archive/2012/02/21/2361802.html 一.概述 习惯了Linux下的网络编程,在还没用智能机之前就一直想 ...
- C++编程规范之23:头文件应该自给自足
摘要: 各司其责:应该确保所编写的每个头文件都能够独自进行编译,为此需要包含其内容所依赖的所有头文件. 如果一个文件包含某个头文件时,还要包含另一个头文件才能工作,就会增加交流障碍,给头文件的用户增添 ...
- 在Linux中创建静态库和动态库 (转)
我们通常把一些公用函数制作成函数库,供其它程序使用.函数库分为静态库和动态库两种.静态 库在程序编译时会被连接到目标代码中,程序运行时将不再需要该静态库.动态库在程序编译时并不会被连接到目标代码中,而 ...
- 有意思的C宏
在Linux内核.嵌入式代码等传统的C代码里,会有一些难以识别的宏定义.我记得在eCos, UBoot, FFmpeg有一些比较BT的宏定义,很难读懂.对于C++程序员来说,最好将这种难读的宏定义转成 ...
- C++ 面向对象学习2 构造方法
Date.h #ifndef DATE_H #define DATE_H class Date{ public: Date(,,);//自定义了构造方法 会覆盖掉默认的无参构造方法 void setD ...