前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL | 聚合函数的使用

MySQL | 聚合函数的使用

作者头像
Zkeq
发布2022-05-18 15:34:56
1.1K0
发布2022-05-18 15:34:56
举报
文章被收录于专栏:Zkeq

数据操作语言:聚合函数

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

代码语言:javascript
复制
SELECT AVG(sal+IFNULL(comm,0)) AS avg
FROM t_emp;

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

SELECT SUM(sal) FROM t_emp
WHERE deptno IN (10,20);

代码语言:javascript
复制
SELECT SUM(sal)
FROM t_emp WHERE deptno IN(10,20);

MAX 函数
  • MAX 函数用于获得非空值的最大值。
代码语言:javascript
复制
SELECT MAX(comm) FROM t_emp;

  • 问题1:查询10和20部门中,月收入最高的员工?
代码语言:javascript
复制
SELECT MAX(sal+IFNULL(comm,0)) FROM t_emp
WHERE deptno IN(10,20)

  • 问题2:查询员工名字最长的是几个字符?
代码语言:javascript
复制
SELECT MAX(LENGTH(ename)) FROM t_emp;

MIN 函数
  • MIN 函数用于获得非空值的最小值。
代码语言:javascript
复制
SELECT MIN(empno) FROM t_emp;
SELECT MIN(hiredate) FROM t_emp;

AVG 函数
  • AVG 函数用于获得非空值的平均值,非数字数据统计结果为 0
代码语言:javascript
复制
SELECT AVG(sal+IFNULL(comm,0)) FROM t_emp;

SELECT AVG(ename) FROM t_emp;

COUNT 函数
  • COUNT(*) 用于获得包含空值的记录数,COUNT(列名) 用于获得包含非空值的记录数。
代码语言:javascript
复制
SELECT COUNT(*) FROM t_emp;

SELECT COUNT(comm) FROM t_emp;

代码语言:javascript
复制
SELECT 
	COUNT(*), COUNT(comm)
FROM t_emp;

  • 查询 10 和 20 部门中,底薪超过 2000 元并且工龄超过 15 年的员工人数?
代码语言:javascript
复制
SELECT COUNT(*) FROM t_emp
WHERE deptno IN(10,20) AND sal>= 2000
AND DATEDIFF(NOW(), hiredate)/365>=15;

  • 查询 1985 年以后入职的员工,底薪超过公司平均底薪的员工数量?
代码语言:javascript
复制
SELECT COUNT(*) FROM t_emp
WHERE hiredate>="1985-01-01"
AND sal>AVG(sal); -- XXXXXXXX
-- 聚合函数永远不能出现在 WHERE 子句里面
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-04-26,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 什么是聚合函数
  • SUM 函数
  • MAX 函数
  • MIN 函数
  • AVG 函数
  • COUNT 函数
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档