Skip to main content

Command Palette

Search for a command to run...

MySQL | 聚合函数的使用

Published
1 min read
MySQL | 聚合函数的使用

数据操作语言:聚合函数

什么是聚合函数

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

SUM 函数

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

SELECT SUM(sal) FROM t_emp
WHERE deptno IN (10,20);
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;
SELECT 
    COUNT(*), COUNT(comm)
FROM t_emp;
  • 查询 10 和 20 部门中,底薪超过 2000 元并且工龄超过 15 年的员工人数?
SELECT COUNT(*) FROM t_emp
WHERE deptno IN(10,20) AND sal>= 2000
AND DATEDIFF(NOW(), hiredate)/365>=15;
  • 查询 1985 年以后入职的员工,底薪超过公司平均底薪的员工数量?
SELECT COUNT(*) FROM t_emp
WHERE hiredate>="1985-01-01"
AND sal>AVG(sal); -- XXXXXXXX
-- 聚合函数永远不能出现在 WHERE 子句里面
8 views

More from this blog

MySQL | 表的内连接

数据操作语言:表连接查询(一) 从多张表中提取数据 从多张表提取数据,必须指定关联的条件。如果不定义关联条件就会出现无条件连接,两张表的数据会交叉连接,产生 笛卡尔积。 规定了连接条件的表连接语句,就不会出现笛卡尔积。 # 查询每名员工的部门信息 SELECT e.empno,e.ename,d.dname FROM t_emp e JOIN t_dept d ON e.deptno=d.deptno; 表连接的分类 表连接分为两种:内连接 和 外连接 内连接是结果集中只保留符合...

May 16, 20221 min read13
MySQL | 表的内连接

MySQL | 分组查询的应用

数据操作语言:分组查询 为什么要分组? 默认情况下汇总函数是对全表范围内的数据做统计 GROUP BY 子句的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对每个小区域分别进行数据汇总处理 SELECT deptno,AVG(sal) FROM t_emp GROUP BY deptno; SELECT deptno,ROUND(AVG(sal)) FROM t_emp GROUP BY deptno; -- ROUND 取整 逐级分组 数据库支持多列分组条件,执行的时候...

Apr 27, 20221 min read10
MySQL | 分组查询的应用
U

Untitled Publication

173 posts