MySQL-分组函数

041-分组函数

重点:所有的分组函数都是自动忽略NULL的
分组函数的执行原则:先分组,然后对每一组数据执行分组函数。如果没有分组语句group by的话,整张表的数据自成一组。

分组函数包括五个:

  • max:最大值
  • min:最小值
  • avg:平均值
  • sum:求和
  • count:计数
sql 复制代码
select sum(sal) from emp;
select lower(ename) from emp;
select max(sal) from emp;
select sum(comm) from emp;
select count(comm) from emp; 统计这个字段当中不为空的个数
select count(*) from emp; 统计表中共有多少条记录(表中的总行数)


分组函数不能直接使用在where子句当中

select ename,job from emp where sal > avg(sal); 这个会报错的

原因:分组的行为是在where执行之后才开始的。

sql 复制代码
select ename, sal from emp where sal>avg(sal);



找出每个岗位的平均薪资

sql 复制代码
select job, avg(sal) from emp group by job;


找出每个部门不同岗位的平均薪资

sql 复制代码
select deptno, job, avg(sal) from emp group by deptno, job;

044-分组查询having

找出除20部分之外,其它部门的平均薪资

sql 复制代码
select deptno, avg(sal) from emp group by deptno having deptno<>20;
select deptno, avg(sal) from emp where deptno<>20 group by deptno;


查询每个部门平均薪资,找出平均薪资高于2000的。

sql 复制代码
select deptno, avg(sal) from emp group by deptno having avg(sal)>2000;

045-分组查询之组内排序

sql 复制代码
select substring_index('http://www.baidu.com','.',1);
select substring_index('http://www.baidu.com','.',2);

不同工作岗位的员工编号按照工资降序排列

sql 复制代码
select group_concat(empno order by sal desc) from emp group by job;


找出每个工作岗位的工资排名在前两名的

sql 复制代码
select substring_index(group_concat(empno order by sal desc),',',2) from emp group by job;

总结单表的DQL语句

select ...5

from ...1

where ...2

group by ...3

having ...4

order by ...6

重点掌握一个完整的DQL语句执行顺序。

相关推荐
OK_boom2 小时前
Dapper的数据库操作备忘
数据库
艺杯羹3 小时前
JDBC之ORM思想及SQL注入
数据库·sql·jdbc·orm·sql注入
blackA_3 小时前
数据库MySQL学习——day4(更多查询操作与更新数据)
数据库·学习·mysql
极限实验室4 小时前
Easysearch 迁移数据之 Reindex From Remote
数据库
朴拙数科4 小时前
基于LangChain与Neo4j构建企业关系图谱的金融风控实施方案,结合工商数据、供应链记录及舆情数据,实现隐性关联识别与动态风险评估
数据库·langchain·neo4j
小李学不完5 小时前
Oracle--SQL事务操作与管理流程
数据库
qq_441996055 小时前
为何 RAG 向量存储应优先考虑 PostgreSQL + pgvector 而非 MySQL?
数据库·mysql·postgresql
Ivan陈哈哈5 小时前
Redis是单线程的,如何提高多核CPU的利用率?
数据库·redis·缓存
AI军哥5 小时前
MySQL8的安装方法
人工智能·mysql·yolo·机器学习·deepseek
小光学长6 小时前
基于vue框架的电信用户业务管理系统的设计与实现8ly70(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库