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过滤。

原文地址:https://www.cnblogs.com/jj0531/p/14683311.html