zoukankan      html  css  js  c++  java
  • mysql 聚集函数和分组

    1、sc表的内容如下:
    mysql> select * from sc order by sid asc;
    +----+-------+-----+-------+
    | ID | SID | CID | SCORE |
    +----+-------+-----+-------+
    | 1 | 10001 | 101 | 70 |
    | 2 | 10001 | 102 | 80 |
    | 4 | 10001 | 103 | 90 |
    | 3 | 10008 | 103 | 50 |
    | 5 | 10008 | 101 | 60 |
    | 6 | 10008 | 102 | 70 |
    +----+-------+-----+-------+
    6 rows in set

    2、求所有成绩的平均值
    mysql> select avg(score) from sc;
    +------------+
    | avg(score) |
    +------------+
    | 70.0000 |
    +------------+
    1 row in set

    考虑,select sid,cid,avg(score) from sc;的结果是什么?
    这个时候平均值只有一个,而sid,cid都是有多个,这种情况,sid,cid取第一条记录的值,sid,cid的值也没有意义。如果某一列所有的值都相同,才有意义。

    3、求每一个学生的平均值
    mysql> select sid,cid,avg(score) from sc group by sid;
    +-------+-----+------------+
    | sid | cid | avg(score) |
    +-------+-----+------------+
    | 10001 | 101 | 80.0000 |
    | 10008 | 103 | 60.0000 |
    +-------+-----+------------+
    2 rows in set
    这个时候,sid的值是有意义的,而cid的值没有意义。

  • 相关阅读:
    SQL语句大全
    网页常用小技巧
    卡通时钟代码
    舒服的颜色2
    静态代码
    Hibernate工作原理
    SQl多表查询优化 高效率SQL语句
    Hibernate API、对象状态、HQL、Criteria
    MySQL 学习笔记
    intramart知识
  • 原文地址:https://www.cnblogs.com/nzbbody/p/4572699.html
Copyright © 2011-2022 走看看