在多列上使用分组依据

在多列上使用分组依据,第1张

在多列上使用分组依据

Group By X
意味着 将所有具有相同X值的那些放在一组

Group By X, Y
意味着 将所有具有相同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_Selectiongroup by Subject

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

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

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

如果我们要到

group by
两列:

select Subject, Semester, Count(*)from Subject_Selectiongroup by Subject, Semester

我们会得到这个:

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

这是因为,当我们按两列分组时,是说 “将它们分组,以便所有具有相同主题和学期的人都在同一组中,然后计算所有聚合函数 (计数,总和,平均值等)。 )
对于每个这些基团”的 。在这个例子中,这是由事实证明,当我们指望他们,有 3 人在第一学期做ITB001和 2
做在学期2.两者的人做MKB114在第一学期,所以没有第2学期的行(没有数据适合“ MKB114,第2学期”组)

希望这是有道理的。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5566163.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-14
下一篇 2022-12-14

发表评论

登录后才能评论

评论列表(0条)

保存