如何解决在多列上使用分组依据
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
,它是如何工作的,又意味着什么呢?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。