1、分组查询
分组函数(多行处理函数)
count |
取得记录数 |
sum |
求和 |
avg |
取平均 |
max |
取最大的数 |
min |
取最小的数 |
- 分组函数也叫:多行处理函数。
多行处理函数的特色:输入多行,最终输出的结果是1行。
- 分组函数自动忽略NULL。
- 全部的分组函数都是对“某一组”数据进行操做的。
- 注意:分组函数不能直接使用在 where 关键字后面。
案例:web
- 取得全部的员工数
select count(*) from emp;
- 取得薪水的合计
select sum(sal) from emp;
单行处理函数
- 输入一行,输出一行。
- 注意:全部数据库规定,只要有NULL参与的运算结果必定是NULL。
使用ifnull() 空处理函数
语法:
ifnull(可能为NULL的数据,被当作什么处理) : 单行处理函数。sql
案例:数据库
- 计算每一个员工的年薪
分析:年薪=(工资+奖金)*12,有的人可能没有奖金,这个字段可能为空,使用ifnull函数将为null的奖金看成0处理。
select ename,(sal+ifnull(comm,0))*12 as yearsal from emp;
分组查询
- group by : 按照某个字段或者某些字段进行分组。
- having : having是对分组以后的数据进行再次过滤。
- 注意:
分组函数通常都会和group by联合使用,而且任何一个分组函数(count sum avg max min)都是在group by语句执行结束以后才会执行的。
当一条sql语句没有group by的话,整张表的数据会自成一组。
当一条语句中有group by的话,select后面只能跟分组函数和参与分组的字段。svg
案例:函数
- 取得每一个工做岗位的工资合计,要求显示岗位名称和工资合计
select job,sum(sal) from emp group by job;
- 每一个工做岗位的平均薪资
select job,avg(sal) from emp group by job;
- 找出每一个部门不一样工做岗位的最高薪资。
select deptno,job,max(sal) from emp group by deptno,job;
- 找出每一个部门的最高薪资,要求显示薪资大于2900的数据。
select deptno,max(sal) from emp where sal>2900 group by deptno;
- 找出每一个部门的平均薪资,要求显示薪资大于2000的数据。
select deptno,avg(sal) from emp where sal>2000 group by deptno;
总结一个完整的DQL语句
执行顺序:
3d
查询结果集的去重
- distinct关键字去除重复记录
- distinct只能出如今全部字段的最前面。
案例:xml
- 统计岗位的数量
select count( distinct job) from emp;
2、链接查询
1.根据语法出现的年代来划分:SQL9二、SQL99
2.根据表的链接方式来划分:
内链接:等值链接、非等值链接、自链接
外链接:左外链接(左链接)、右外链接(右链接)blog
内链接:
- 假设A和B表进行链接,使用内链接的话,凡是A表和B表可以匹配上的记录查询出来,这就是内链接。AB两张表没有主副之分,两张表是平等的。
等值链接:
- 最大特色是:条件是等量关系。
- 语法:
inner能够省略的,带着inner目的是可读性好一些。
案例:
- 查询每一个员工的部门名称,要求显示员工名和部门名。
非等值链接:
自连接:
案例:
- 找出每一个员工的上级领导,要求显示员工名和对应的领导名。
外链接:
左外链接(左链接):表示左边的这张表是主表。
右外链接(右链接):表示右边的这张表是主表。
左链接有右链接的写法,右链接也会有对应的左链接的写法。
案例:
- 找出每一个员工的上级领导?(全部员工必须所有查询出来。)
ps: 另外一种写法
3张表进行查询
注意:
案例:
- 找出每个员工的部门名称以及工资等级。
- 找出每个员工的部门名称、工资等级、以及上级领导。
3、union( 能够合并集合(相加))
案例:
- 查询 job 包含 MANAGER 和包含 SALESMAN 的员工
- 采用 union 来合并
今天的分享就到这里啦!!~感谢你们的观看,但愿对你们有帮助的话麻烦给个丝滑三连击。(点赞+转发+关注) 一块儿加油,一块儿努力,一块儿秃见成效!