A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 曹恒虎 黑马帝   /  2011-12-1 18:23  /  3559 人查看  /  7 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 曹恒虎 于 2011-12-1 18:28 编辑

select age, count(*) from student group by age having age>18
select age, count(*) from student where age>18 group by age
大家觉得这两句有什么不一样呢?一个是分组后再过滤,一个是过滤后再分组,但得到的结果是一样呢。

评分

参与人数 1技术分 +1 收起 理由
朱勋 + 1

查看全部评分

7 个回复

倒序浏览
http://www.cnblogs.com/bestchen_1/articles/2079568.html    看看吧,说的很详细。

评分

参与人数 1技术分 +1 收起 理由
朱勋 + 1

查看全部评分

回复 使用道具 举报
having必须放在有group by的语句中,而where可以放在任何语句里

评分

参与人数 1技术分 +1 收起 理由
朱勋 + 1

查看全部评分

回复 使用道具 举报
where :统计前过滤,过滤的是原始数据。
having:统计后过滤,过滤的是统计结果。第一句查询语句是正确的。

评分

参与人数 1技术分 +2 收起 理由
陈涛 + 2

查看全部评分

回复 使用道具 举报
在SQL server中select语句中where子句指定选择的条件来实现的。where子句必须跟在from子句后面,group by子句主要用于根据字段对行分组。使用group by子句和聚合函数对数据进行分组后,还可以使用having子句对分组数据进行进一步的筛选。在select语句中,当where、group by和having子句都被使用时,要注意它们的作用和执行顺序。where用于筛选由from子句指定的数据对象,group by用于对where的结果进行分组,having则是对group by以后的分组数据进行过滤。
例如:
     select 学号
   where 成绩>90
   group by 学号
   having count(*)>2

评分

参与人数 1技术分 +3 收起 理由
陈涛 + 3

查看全部评分

回复 使用道具 举报
GROUP BY:根据字段进行分组。例如:select 学号  ,AVG  (成绩)from 学生表  GROUP BY 学号  
where:用来限定SQl语句的查询条件。例如:select *from XSB  where   age >20
having:一般在使用GROUP BY之后对分组字段进一步的筛选。
例如:select 学号  ,AVG  (成绩)from 学生表  GROUP BY 学号  HAVING AVG(成绩)  >=60

评分

参与人数 1技术分 +3 收起 理由
陈涛 + 3

查看全部评分

回复 使用道具 举报
曹恒虎 黑马帝 2011-12-1 20:38:38
7#
闫炳颖 发表于 2011-12-1 19:04
where :统计前过滤,过滤的是原始数据。
having:统计后过滤,过滤的是统计结果。第一句查询语句是正确的。 ...

第二句也是正确的呢,而且结果一样

评分

参与人数 1技术分 +2 收起 理由
陈涛 + 2

查看全部评分

回复 使用道具 举报
董志 黑马帝 2011-12-2 14:00:58
8#
还是用where比较好,where把原始数据先过滤了,之后再分组。
而group by先分组,再从组中过滤,性能存在问题,但是数据量
小时不会有什么明显区别。

评分

参与人数 1技术分 +2 收起 理由
陈涛 + 2

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马