Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1002357
  • 博文数量: 152
  • 博客积分: 4937
  • 博客等级: 上校
  • 技术积分: 1662
  • 用 户 组: 普通用户
  • 注册时间: 2007-10-05 16:55
文章分类

全部博文(152)

文章存档

2013年(12)

2012年(6)

2011年(58)

2010年(43)

2009年(1)

2008年(15)

2007年(17)

我的朋友

分类: WINDOWS

2012-09-10 10:47:26

sql中having ----------------------------

select sname,sum(smon)

from student

group by sname

having sum(smon)>7

--------------------------------

下面是正文

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

执行where子句查找符合条件的数据;

使用group by 子句对数据进行分组;

对group by 子句形成的组运行聚集函数计算每一组的值;

最后用having 子句去掉不符合条件的组。

select dno,count(*)

   from employee

   group by dno

   having count(*)>3

需要注意:having 子句中的每一个元素也必须出现在select列表中。有些例外,如oracle.

having子句和where子句都可以用来设定限制条件以使查询结果满足一定的条件限制。

having子句限制的是组,而不是行。where子句中不能使用聚集函数,而having子句中可以。

select dno,sum(salary)

   from employee

   group by dno

   having sum(salary)>10000

小注:

  SQL语言中设定集合函数的查询条件时使用HAVING从句而不是WHERE从句。通常情况下,HAVING从句被放置在SQL命令的结尾处。

阅读(546) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~