关于分组函数(聚合函数)

分组函数:也叫"多行处理函数"或"聚合函数" (特点:输入多行,最终输出一行)
            用于对表中指定字段下的内容进行统计的函数。

    - count()  计数(返回指定字段下内容不为null的数据个数)
            统计员工数量: 
            select count(ename) from emp;

                        
            count(*)是统计表中所有数据行的个数,它不考虑数据行是否存在null
            select count(*) from emp;

                         
     
            查询有具体补助(补助不为null)的人员数量
            select count(comm) from emp;

        ​​​​​​​        ​​​​​​​        

    - sum()  求和
            工资求和:
            select sum(sal) from emp;

        ​​​​​​​        ​​​​​​​        

    - avg()  平均数
            计算平均工资:
            select avg(sal) from emp;

        ​​​​​​​        ​​​​​​​        

     max()  最大值
            找出最高薪资:
            select max(sal) from emp;

        ​​​​​​​        ​​​​​​​        

    - min()  最小值
            找出最低薪资:
            select min(sal) from emp;

        ​​​​​​​        ​​​​​​​        

       【注意:分组函数在使用的时候必须先进行分组,然后才能使用。如果没有分组,整张表默认为一组.】

    分组函数在使用的时候需要注意几点:
        第一:分组函数自动忽略null,不需要提前对null进行处理。

        第二:count(具体字段):表示统计该字段下所有不为空的元素总个数。
                   count(*):表示统计表中总记录条数,因为在数据库中不能出现一条记录中所有的字段都
                           为null。

        第三:分组函数不能直接使用在where子句中。
                  
找出比平均工资高的员工信息:下面的命令语句是错误的(说完分组查询就明白了)
                  select ename,sal from emp 
where sal > avg(sal);(这样写命令是错误的)

                  这个问题可以通过子查询来解决:

                  select ename,sal from emp where sal > (select avg(sal) from emp);

         第四:所有的分组函数可以组合起来一起用
                  select sum(sal),max(sal),min(sal),avg(sal),count(*) from emp;
        ​​​​​​​ 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值