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

    分组函数:

      count            计数函数   计算某个字段出现的里面的内容 不为null 就+1

      sum(需要计算的那l列字段);·  求和函数

      avg()            求和函数

      max()            求字段中 最大值

      min()            求字段中 最小值

    注意:

      1.所有的分组函数都是对“某一组”数据进行操作的。

      2.分组函数自动忽略NULL。

      3.SQL语句当中有一个语法规则,分组函数不可直接使用在where子句当中。why????

        怎么解释?
            因为group by是在where执行之后才会执行的。

      

    count(*)和count(具体的某个字段),他们有什么区别?
      count(*):不是统计某个字段中数据的个数,而是统计总记录条数。(和某个字段无关)
      count(comm): 表示统计comm字段中不为NULL的数据总数量。

    分组函数也能组合起来用:
      select count(*),sum(sal),avg(sal),max(sal),min(sal) from emp;

    单行处理函数
      什么是单行处理函数?
        输入一行,输出一行。

      计算每个员工的年薪?
      select ename,(sal+comm)*12 as yearsal from emp;  
        重点:所有数据库都是这样规定的,只要有NULL参与的运算结果一定是NULL。
        使用ifnull函数: 

        fnull() 空处理函数?
          ifnull(可能为NULL的数据,被当做什么处理) : 属于单行处理函数。
            select ename,ifnull(comm,0) as comm from emp;

    group by 和 having

      group by : 按照某个字段或者某些字段进行分组。
      having : having是对分组之后的数据进行再次过滤。

    注意:分组函数一般都会和group by联合使用,这也是为什么它被称为分组函数的原因。
    并且任何一个分组函数(count sum avg max min)都是在group by语句执行结束之后才会执行的。
    当一条sql语句没有group by的话,整张表的数据会自成一组。

    select ename,max(sal),job from emp group by job;
    以上在mysql当中,查询结果是有的,但是结果没有意义,在Oracle数据库当中会报错。语法错误。
    Oracle的语法规则比MySQL语法规则严谨。
    记住一个规则:当一条语句中有group by的话,select后面只能跟分组函数和参与分组的字段。

    where后面不能使用分组函数:
    select deptno,avg(sal) from emp where avg(sal) > 2000 group by deptno; // 错误了。
    这种情况只能使用having过滤。

  • 相关阅读:
    对webpack的初步研究7
    对后端返回的时间进行升序的排序
    对webpack的初步研究6
    对webpack的初步研究5
    对webpack的初步研究4
    对webpack的初步研究3
    计算两个时间之间的天数、小时等
    对webpack的初步研究2
    线程_进程间通信Queue合集
    线程_threading合集
  • 原文地址:https://www.cnblogs.com/jj0531/p/14683311.html
Copyright © 2011-2022 走看看