0
点赞
收藏
分享

微信扫一扫

SQL学习:八

玉字璧 2022-04-01 阅读 45

分组数据

1、数据分组

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子句,这个子句将返回所有分组。
``` sql server
SELECT vend_id,COUNT(*) AS num FROM Products GROUP BY vend_id;

2、过滤分组

HAVING 子句 :过滤分组 (可以理解为分组中的WHERE)。
WHERE过滤行。
WHERE在数据分组前进行过滤,HAVING在数据分组后进行过滤。
HAVING 支持所有的WHERE操作符。
```SQL SERVER
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子句及其顺序**
|子句|说明|是否必须使用|
|----|----|---|
|SELECT|要返回的列或表达式|是|
|FROM|从中检索数据的表|仅在从表选择数据时使用|
|WHERE|行级过滤|否|
|GROUP BY|分组说明|仅在按组计算聚集时使用|
|HAVING|组级过滤|否|
|ORDER BY|输出排序顺序|否|
举报

相关推荐

0 条评论