导读 `GROUP BY` 是 SQL 语言中的一个子句,用于结合聚合函数,根据一个或多个列对结果集进行分组。它通常与聚合函数如 `SUM()`, `AVG()`,...
`GROUP BY` 是 SQL 语言中的一个子句,用于结合聚合函数,根据一个或多个列对结果集进行分组。它通常与聚合函数如 `SUM()`, `AVG()`, `COUNT()`, `MAX()`, `MIN()` 等一起使用。
当你使用 `GROUP BY` 子句时,查询的结果将根据指定的列或表达式进行分组,并且每个分组都会返回聚合的结果。每个分组中的数据都是唯一的,而聚合函数会为每个分组返回单个值。
举个例子,假设我们有一个销售数据表 `sales_data`,包含列 `product_id`, `year`, 和 `revenue`。如果你想知道每种产品在每年的总销售额,你可以这样查询:
```sql
SELECT product_id, year, SUM(revenue) as total_revenue
FROM sales_data
GROUP BY product_id, year;
```
这个查询会返回每种产品在每年的总销售额。`GROUP BY` 子句确保 `product_id` 和 `year` 的组合是唯一的,并且为每个这样的组合计算总销售额。
注意:当你在 `GROUP BY` 子句中使用多个列时,数据的分组是基于这些列的联合组合进行的。也就是说,只有当所有列的组合是唯一的,数据才会被分为一个组。如果只使用单个列进行分组,那么基于该列的值进行分组。