group by,having,where

--举例子说明:查询table表查询每个班级中年龄大于20,性别为男的人数
select COUNT(*)as '>20岁人数',classid  from Table1 where sex='男' group by classid,age having age>20 
--须要注意说明:当同时含有where子句、group by 子句 、having子句及汇集函数时,执行顺序以下:
--执行where子句查找符合条件的数据;
--使用group by 子句对数据进行分组;对group by 子句造成的组运行汇集函数计算每一组的值;最后用having 子句去掉不符合条件的组。
--having 子句中的每个元素也必须出如今select列表中。有些数据库例外,如oracle.
--having子句和where子句均可以用来设定限制条件以使查询结果知足必定的条件限制。
--having子句限制的是组,而不是行。where子句中不能使用汇集函数,而having子句中能够。web

相关文章
相关标签/搜索