如何将 MySQL 返回的结果集分组?
mysqlmysqli database
这可以通过在 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)
上述查询将结果集分为三组:助理教授,人数总计 1,平均工资为 74000;助理教授,人数总计 2,平均工资为 55000;教授,人数总计 2,平均工资为 87500。