在多列上使用分组依据

问题描述

Group By X意味着 。

Group By X, Y意味着 。

为了举例说明,假设我们有一个下表,该表与谁在大学里修读什么科目有关:

Table: Subject_Selection

+---------+----------+----------+
| Subject | Semester | Attendee |
+---------+----------+----------+
| ITB001  |        1 | John     |
| ITB001  |        1 | Bob      |
| ITB001  |        1 | Mickey   |
| ITB001  |        2 | Jenny    |
| ITB001  |        2 | James    |
| MKB114  |        1 | John     |
| MKB114  |        1 | Erica    |
+---------+----------+----------+

group by仅在主题列上使用a时;说:

select Subject, Count(*)
from Subject_Selection
group by Subject

您将获得类似以下内容的信息:

+---------+-------+
| Subject | Count |
+---------+-------+
| ITB001  |     5 |
| MKB114  |     2 |
+---------+-------+

…因为ITB001有5个条目,MKB114有2个条目

如果我们要到group by两列:

select Subject, Semester, Count(*)
from Subject_Selection
group by Subject, Semester

我们会得到这个:

+---------+----------+-------+
| Subject | Semester | Count |
+---------+----------+-------+
| ITB001  |        1 |     3 |
| ITB001  |        2 |     2 |
| MKB114  |        1 |     2 |
+---------+----------+-------+

这是因为,当我们按两列分组时,是说 (计数,总和,平均值等)。 ) 。在这个例子中,这是由事实证明,当我们指望他们,有 人在第一学期做ITB001和 做在学期2.两者的人做MKB114在第一学期,所以没有第2学期的行(没有数据适合“ MKB114,第2学期”组)

希望这是有道理的。

解决方法

我明白这一点GROUP BY x

但是GROUP BY x,y,它是如何工作的,又意味着什么呢?