如何将 MySQL 返回的结果集分成组?


这可以通过在 SELECT 语句中使用 GROUP BY 子句来实现。我们可以使用 GROUP BY 子句指定一个列作为分组标准。由于指定的这个分组标准,在特定列中具有相同值的行的会被视为一个组。通过这种方式,MySQL SELECT 语句返回的结果集将被分成组。

示例

以下是一个很好的示例,可以帮助你理解它:

我们有一个名为“employees”的表,如下所示:

mysql> Select * from employees;
+------+-------------+--------+------------+
| id   | designation | Salary | DoJ        |
+------+-------------+--------+------------+
| 100  | Asst.Prof   | 50000  | 2016-06-15 |
| 300  | Prof        | 85000  | 2010-05-18 |
| 250  | Asso.Prof   | 74000  | 2013-02-12 |
| 400  | Prof        | 90000  | 2009-05-19 |
| 200  | Asst.Prof   | 60000  | 2015-05-11 |
+------+-------------+--------+------------+
5 rows in set (0.00 sec)

现在,借助以下脚本,我们将输出分成组:

mysql> select designation, count(*), AVG(salary) from employees group by designation;
+-------------+----------+-------------+
| designation | count(*) | AVG(salary) |
+-------------+----------+-------------+
| Asso.Prof   | 1        | 74000.0000  |
| Asst.Prof   | 2        | 55000.0000  |
| Prof        | 2        | 87500.0000  |
+-------------+----------+-------------+
3 rows in set (0.00 sec)

以上查询将结果集分成 Asso.Prof 组,总数为 1,平均工资为 74000;Asst.Prof 组,总数为 2,平均工资为 55000;Prof 组,总数为 2,平均工资为 87500。

更新时间: 2020年6月20日

893 次查看

开启你的 职业生涯

通过完成课程获得认证

开始学习
广告