zoukankan      html  css  js  c++  java
  • mysql分组查询

    有一张学生选课表

    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

    我们想统计每门课程有多少个学生报名

    select subject,count(*) from
    Subject_Selection
    group by subject

    得到如下结果

    Subject    Count
    ------------------------------
    ITB001     5
    MKB114     2

    group by X意思是将所有相同的X字段的值的记录放在一个分组里

    group by X,Y是将所有相同X字段值和Y字段值的记录放在一个分组里

    我们接下来统计每门学科每学期有多少人选择

    select subject,semester,count(*) from Subject_Selection group by subject,semester

    上面sql的意思是,对subejct_selection表中的数据进行分组,将具有相同subject和semester字段值的记录放到同一个分组里去,然后对每个分组中的数据应用聚合函数(count,sum,avg,etc)

    结果是:

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

    从表中的记录我们可以看出这个分组结果是正确的,有3个学生在第一学期选择了ITB001,2个学生在第二学期选择了ITB001,还有两个学生在第一学期选择了MKB114,没人在第二学期选择MKB114

  • 相关阅读:
    进程,线程(thread)
    PHP权限分配思路
    xml simpleXML_load_file(), simpleXML_load_string()
    XML基础
    php QQ登录
    ci验证码
    jquery中的 .html(),.val().text()
    ci 用本身 email 类发 email
    Objective-C 装饰模式--简单介绍和使用
    Objective-C 外观模式--简单介绍和使用
  • 原文地址:https://www.cnblogs.com/z-x-y/p/9802382.html
Copyright © 2011-2022 走看看