• 数据库中的分组/多行处理/聚合函数


    分组函数
    • 分类:
      count 计数
      sum 求和
      avg 平均值
      max 最大值
      min 最小值
      注:
      ①所有的分组函数都是对“某一组"数据进行操作的。
      ②分组函数自动忽略空值(NULL),不需要手动的加where条件排除空值。
      ③在数据库运算中,NULL参与的运算,结果一定是NULL。
      ④分组函数不能直接使用在where关键字后面。
      在这里插入图片描述
    • 例子:
      count
    SELECT count(cust_id) FROM boot_crm.customer;
    

    在这里插入图片描述

    count(*)和count(具体的某个字段),有什么区别?

    1、count(*):不是统计某个字段中数据的个数,而是统计总记录条数。(和某个字段无关)
    2、count(comm):表示统计comm字段中不为NULL的数据总数量。

    多行处理/聚合函数及单行处理函数

    1、分组函数又叫多行处理函数或聚合函数,特点是:输入多行,最终输出的结果是1行。
    单行处理函数:输入一行,输出一行。
    2、IFNULL() 函数(空函数处理)
    IFNULL() 函数用于判断第一个表达式是否为 NULL,如果为 NULL 则返回第二个参数的值,如果不为 NULL 则返回第一个参数的值。
    IFNULL() 函数语法格式为:

    IFNULL(expression, alt_value)
    

    例子:

    SELECT cost_name, ifnull(cost_value, 'Y') 
    FROM mysql.engine_cost;
    

    在这里插入图片描述

    GROUP BY
    • group by和having
      1、group by:按照某个字段或者某些字段进行分组。
      2、having:having是对分组之后的数据进行再次过滤。
      3、例:找出每个工作岗位的最高薪资。
    select max(sal) from emp group by job;
    
    • 重要结论
      1、分组函数一般都会和group by联合使用。
      2、任何一个分组函数都是在group by语句执行结束之后才会执行的。
      3、当一条sql语句没有group by的话,整张表的数据会自成一组。
      4、where后面不能使用分组函数。
      5、当一条语句中有group by的话,select后面只能跟分组函数和参与分组的字段。
    多字段分组
    • 找出每个部门不同工作岗位的最高薪资。
    SELECT DEPTNO, JOB, max(SAL) 
    FROM powernode.emp
    group by DEPTNO, JOB;
    

    在这里插入图片描述

    • 找出每个部门的最高薪资,要求显示薪资大于2900的数据。
      方法一(先分组,再过滤,效率较低):
    select max(SAL)
    FROM powernode.emp
    group by DEPTNO
    having max(SAL) > 2900;
    

    在这里插入图片描述
    方法二(先过滤,再分组,效率较高,所以尽量使用where):

    select max(SAL)
    FROM powernode.emp
    where SAL > 2900
    group by DEPTNO;
    

    在这里插入图片描述

    • 不能使用where的情况:找出每个部门的平均薪资,要求显示薪资大于2000的数据。
    select DEPTNO, avg(SAL)
    FROM powernode.emp
    group by DEPTNO
    having avg(SAL)>2000;
    

    在这里插入图片描述

  • 相关阅读:
    python爬虫学习
    Java基础知识11--Optional类
    07 Windows访问远程共享文件夹---利用\IP地址
    Springcloud 学习笔记15-打开postman console控制台,查看接口测试打印log日志信息
    Springcloud 学习笔记14-IaaS, PaaS和SaaS的区别
    Springcloud 学习笔记13-使用PostMan上传/下载文件,前后端联合测试
    Java基础知识10--Stream API详解02
    Java基础知识09--Stream API详解01
    洛谷 P2587 [ZJOI2008]泡泡堂(贪心)
    洛谷 P3199 [HNOI2009]最小圈(01分数规划,spfa判负环)
  • 原文地址:https://www.cnblogs.com/yu011/p/13268314.html
Copyright © 2020-2023  润新知