mysql分组函数

2023-12-07 13:49:20 浏览数 (1)

分组函数:

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

0 人点赞