温馨提示×

MySQL WITH ROLLUP如何使用

小樊
91
2024-10-02 09:10:11
栏目: 云计算

MySQL的WITH ROLLUP选项可以在GROUP BY子句后使用,以生成一个额外的汇总行。这个汇总行会显示每个组的总计,以及所有组的总计(如果指定了GROUP BY子句)。

以下是使用WITH ROLLUP的基本语法:

SELECT column1, column2, ...
FROM table_name
GROUP BY column1, column2, ...
WITH ROLLUP;

在这个例子中,column1column2等是你想要根据其进行分组的列。table_name是你要查询的表名。

使用WITH ROLLUP时,你会得到以下结果:

  1. 每个分组的小计(如果存在的话)。
  2. 排除所有分组的大计。
  3. 包括所有分组的大计(如果未指定GROUP BY子句,并且使用了WITH ROLLUP)。

下面是一个具体的例子。假设我们有一个名为sales的表,其中包含以下数据:

+------------+--------+-------+
| product_id | region | sales |
+------------+--------+-------+
| 1          | North  | 100   |
| 1          | South  | 200   |
| 2          | North  | 150   |
| 2          | South  | 50    |
| 3          | North  | 75    |
| 3          | South  | 125   |
+------------+--------+-------+

如果我们执行以下查询:

SELECT product_id, region, SUM(sales)
FROM sales
GROUP BY product_id, region
WITH ROLLUP;

我们会得到以下结果:

+------------+--------+-------+
| product_id | region | sales |
+------------+--------+-------+
| 1          | North  | 100   |
| 1          | South  | 200   |
| 1          | NULL   | 300   |  -- North的总计
| 2          | North  | 150   |
| 2          | South  | 50    |
| 2          | NULL   | 200   |  -- South的总计
| 3          | North  | 75    |
| 3          | South  | 125   |
| 3          | NULL   | 200   |  -- North的总计
| NULL       | NULL   | 600   |  -- 所有产品的总计
+------------+--------+-------+

注意,当分组列中有NULL值时,WITH ROLLUP会为这些NULL值生成一个单独的行。

0