我明白这一点GROUP BY x。
GROUP BY x
但是GROUP BY x, y,它是如何工作的,又意味着什么呢?
GROUP BY x, y
Group By X意味着 将所有具有相同X值的那些放在一组 。
Group By X
Group By X, Y意味着 将所有具有相同X和Y值的那些放在一组中 。
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时;说:
group by
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 | +---------+----------+-------+
这是因为,当我们按两列分组时,是说 “将它们分组,以便所有具有相同主题和学期的人都在同一组中,然后计算所有聚合函数 (计数,总和,平均值等)。 ) 对于每个这些基团”的 。在这个例子中,这是由事实证明,当我们指望他们,有 3 人在第一学期做ITB001和 2 做在学期2.两者的人做MKB114在第一学期,所以没有第2学期的行(没有数据适合“ MKB114,第2学期”组)
希望这是有道理的。