数据操作语言:聚合函数

什么是聚合函数

  • 聚合函数在数据的查询分析中,应用十分广泛。聚合函数可以对数据求和、求最大值和最小值、求平均值等等。
  • 求公司员工的平均月收入是多少?
    SELECT AVG (sal+IFNULL(comm,0)) FROM t_emp;

SUM函数

  • SUM函数用于求和,只能用于数字类型,字符类型的统计结果为0,日期类型统计结果是毫秒数相加。
    SELECT SUM(ename) FROM t_emp;
    SELECT SUM(sal) FROM t_emp WHERE deptno IN(10,20);

MAX函数

  • MAX函数用于获得非空值的最大值。
    SELECT MAX(comm) FROM t_emp;
  • 问题1: 查询10和20部门中,月收入最高的员工?
    SELECT MAX(sal+IFNULL(comm,0)) FROM t_emp WHERE deptno IN (10,20);
  • 问题2: 查询员工名字最长的是几个字符?
    SELECT MAX(LENGTH(ename)) FROM t_emp;

MIN函数

  • MIN函|数用于获得非空值的最小值。
    SELECT MIN(empno) FROM t_emp ;
    SELECT MIN(hiredate) FROM t_emp ;

AVG函数

  • AVG函数用于获得非空值的平均值,非数字数据统计结果为0
    SELECT AVG(sal+IFNULL(comm,0)) FROM t_emp;
    SELECT AVG(ename) FROM t_emp;

COUNT函数

  • COUNT(*)用于获得包含空值的记录数, COUNT(列名) 用于获得包含非空值的记录数
    SELECT COUNT(*) FROM t_emp;
    SELECT COUNT(comm) FROM t_emp;

练习

  1. 查询10和20部门中,底薪超过2000元并且工龄超过15年的员工人数?
SELECT COUNT(*) FROM t_emp 
WHERE deptno IN(10,20) AND sal>2000 
AND DATEDIFF(NOW(),hiredate)/365>15;
  1. 查询1985年以后入职的员工,底薪超过公司平均底薪的员工数量?
SELECT COUNT(*) FROM t_emp
WHERE hiredate>"1985-01-01" 
AND sal>(SELECT AVG(sal) FROM t_emp);
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值