zoukankan      html  css  js  c++  java
  • mysql之group by,order by


    一个例子

    group by

    顾名思义,是按照哪个字段分组,比如按照名字分组,则是所有名字相同的分为一组。在一些计数及求和中用到最多。

    还以上篇文章的学生信息表为例。

    1.求出每个年龄阶段的学生的个数。

    use school;
    -- 求出每个年龄阶段的学生个数
    select * from tb_student;
    select age,count(age) from tb_student group by Age;

    分组结果

    由上面的tb_student表可以看出,23岁的学生有两名,而其他年龄阶段的各有一名。

    在分组的时候,你可以输出计数结果,但如果你如果想输出其他的信息,比如输出名字,这样做是没有意义的。因为只会输出一个,例如:

    select `name`,age,count(age) from tb_student group by Age;

    虽然没有报错,但是这样的统计,并不能让人信服。因为23岁的学生有两名:麻子和孙悟空。

    所以,group by大都和聚合函数配合函数一起使用,聚合聚合,顾名思义就是,将多个结果合成一个结果,比如计数,求和,平均数等函数。

    那如果真的要输出所有23岁的名字的话,那么可以这样:

    MySQL group_concat函数
    完整的语法如下:
    group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator '分隔符'])

    这个函数,可以将分组后拼接内容,也算一个聚合函数,将多个结果拼接成一个结果,也可以拼接的同时进行结果去重。

    select group_concat(`name`,',') as stuName,age,count(age) as AgeCount from tb_student group by Age ;

    将想要的统计内容,分组拼接:

    有上面的结果,也可以看出23岁的学生有两名,分别为麻子,孙悟空。这样统计的结果更具有说服力。

    ordery by

    按哪个字段进行排序,默认升序,desc降序。

    接着在上个例子中按照统计的人数进行降序排列

    use school;
    select group_concat(`name`,',') as stuName,age,count(age) as AgeCount from tb_student group by Age order by count(age) desc;

    排序比较好理解,这里就介绍到这里。

  • 相关阅读:
    安卓模拟器genimotion安装过程
    python3安装过程
    python基础数据类型数字和字符串
    genimotion模拟器和appium环境配置
    ArcEngine中的ICommand和ITool
    BM.AE介绍
    地图数据和版式数据联动
    BM.AE中的命令工具体系
    2021年1月1日 AutoCAD.Net/C#.Net QQ群:193522571获取任意路径dwg文件内所有块在控件中显示并能选择插入当前模型空间
    2021年1月1日 AutoCAD.Net/C#.Net QQ群:193522571用acedGrRead()函数实现一拖多
  • 原文地址:https://www.cnblogs.com/bb3q/p/4539904.html
Copyright © 2011-2022 走看看