分组函数:
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过滤。