GROUP BY子句 :创建分组
①GROUP BY子句可以包含任意数目的列,因而可以对分组进行嵌套,更细致地进行数据分组。
②如果GROUP BY子句中嵌套了分组,数据将在最后指定的分组上进行汇总。
③GROUP BY子句中列出的每一列都必须是检索列或有效的表达式(但不能是聚集函数)。如果在SELECT中使用表达式,则必须在GROUP BY子句中指定相同的表达式。不能使用别名。
④大多数SQL不允许GROUP BY列带有长度可变的数据类型(如文本或备注型字段)。
⑤除聚集计算语句外,SELECT语句中的每一列都必须在GROUP BY子句中给出
⑥如果分组列中包含具有NULL值的行,则NULL将作为一个分组返回。如果列中有多行NULL值,他们将为一组。
⑦GROUP BY子句必须出现在WHERE子句之后,ORDER BY子句之前。
⑧SQL SERVER中支持GROUP BY子句中使用ALL子句,这个子句将返回所有分组。
SELECT vend_id,COUNT(*) AS num FROM Products GROUP BY vend_id;
HAVING 子句 :过滤分组 (可以理解为分组中的WHERE)。
WHERE过滤行。
WHERE在数据分组前进行过滤,HAVING在数据分组后进行过滤。
HAVING 支持所有的WHERE操作符。
SELECT cust_id,COUNT(*) AS orders FROM Orders GROUP BY cust_id HAVING COUNT(*)>=2; SELECT vend_id,COUNT(*) AS num FROM Products WHERE prod_price >=4 GROUP BY vend_id HAVING COUNT(*) >=2;
子句 | 说明 | 是否必须使用 |
---|---|---|
SELECT | 要返回的列或表达式 | 是 |
FROM | 从中检索数据的表 | 仅在从表选择数据时使用 |
WHERE | 行级过滤 | 否 |
GROUP BY | 分组说明 | 仅在按组计算聚集时使用 |
HAVING | 组级过滤 | 否 |
ORDER BY | 输出排序顺序 | 否 |