mysql 联接结果集函数_MySQL学习笔记汇总(二)——分组查询、链接查询、union...

1、分组查询

分组函数(多行处理函数)

count

取得记录数

sum

求和

avg

取平均

max

取最大的数

min

取最小的数

分组函数也叫:多行处理函数。

多行处理函数的特色:输入多行,最终输出的结果是1行。

分组函数自动忽略NULL。

全部的分组函数都是对“某一组”数据进行操做的。

注意:分组函数不能直接使用在 where 关键字后面。

案例:web

取得全部的员工数

select count(*) from emp;

b49023a60165630ae62e83e259a7faf1.png

取得薪水的合计

select sum(sal) from emp;

c8cbced93095b75318952370dddb0a5a.png

单行处理函数

输入一行,输出一行。

注意:全部数据库规定,只要有NULL参与的运算结果必定是NULL。

使用ifnull() 空处理函数

语法:

ifnull(可能为NULL的数据,被当作什么处理) : 单行处理函数。sql

案例:数据库

计算每一个员工的年薪

分析:年薪=(工资+奖金)*12,有的人可能没有奖金,这个字段可能为空,使用ifnull函数将为null的奖金看成0处理。

select ename,(sal+ifnull(comm,0))*12 as yearsal from emp;

ae51426d385d38355786110d1063fd13.png

分组查询

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;

6ccfb98b3d79a5f8f4c16f69a81048b5.png

每一个工做岗位的平均薪资

select job,avg(sal) from emp group by job;

f7228560cacfc7c9779d5608d62a9dea.png

找出每一个部门不一样工做岗位的最高薪资。

select deptno,job,max(sal) from emp group by deptno,job;

7b6e819e92089102c0d1eb3477e5af42.png

找出每一个部门的最高薪资,要求显示薪资大于2900的数据。

select deptno,max(sal) from emp where sal>2900 group by deptno;

137aba5bddc80dba727fe31b535a53da.png

找出每一个部门的平均薪资,要求显示薪资大于2000的数据。

select deptno,avg(sal) from emp where sal>2000 group by deptno;

582b12b1a0ea3e5bc7f488a79c66cd5a.png

总结一个完整的DQL语句

执行顺序:

ea39385e700ad6a1b73920f59a9a246c.png3d

查询结果集的去重

distinct关键字去除重复记录

distinct只能出如今全部字段的最前面。

案例:xml

统计岗位的数量

select count( distinct job) from emp;

29c5a8df2ce91dc250db22a5f1e7376c.png

2、链接查询

多张表联合查询取出数据

链接查询分类:

1.根据语法出现的年代来划分:SQL9二、SQL99

2.根据表的链接方式来划分:

内链接:等值链接、非等值链接、自链接

外链接:左外链接(左链接)、右外链接(右链接)blog

内链接:

假设A和B表进行链接,使用内链接的话,凡是A表和B表可以匹配上的记录查询出来,这就是内链接。AB两张表没有主副之分,两张表是平等的。

等值链接:

最大特色是:条件是等量关系。

语法:

8bac96986f1118d258ef4431373e18e7.png

inner能够省略的,带着inner目的是可读性好一些。

案例:

查询每一个员工的部门名称,要求显示员工名和部门名。

f6bf368ed269ebf136c1fb2e15199f54.png

非等值链接:

最大的特色是:链接条件中的关系是非等量关系。

案例:图片

找出每一个员工的工资等级,要求显示员工名、工资、工资等级。

aeeb85a15cbfee5762ce2d84fdaa8efc.pngit

自连接:

最大的特色是:一张表看作两张表。本身链接本身。

案例:

找出每一个员工的上级领导,要求显示员工名和对应的领导名。

4016a02c3f862a4ff175beb29da0afa4.png

外链接:

外链接最重要的特色是:主表的数据无条件的所有查询出来。

假设A和B表进行链接,使用外链接的话,AB两张表中有一张表是主表,一张表是副表,主要查询主表中的数据,捎带着查询副表,当副表中的数据没有和主表中的数据匹配上,副表自动模拟出NULL与之匹配。

左外链接(左链接):表示左边的这张表是主表。

右外链接(右链接):表示右边的这张表是主表。

左链接有右链接的写法,右链接也会有对应的左链接的写法。

案例:

找出每一个员工的上级领导?(全部员工必须所有查询出来。)

f77bb04a88fb6e8bd3a63526ce7a95f9.png

ps: 另外一种写法

36f1e7a56bf3d12261d266fddcc07d86.png

3张表进行查询

注意:

9cc7a136251499679a177dda563dd325.png

案例:

找出每个员工的部门名称以及工资等级。

ab7709f0ca1872f8ed73d9f953a7f088.png

找出每个员工的部门名称、工资等级、以及上级领导。

a9bd6ee4dfeb833231502bbbe55297bd.png

3、union( 能够合并集合(相加))

案例:

查询 job 包含 MANAGER 和包含 SALESMAN 的员工

f203200a617dd41aa87f84ec1a0c285f.png

采用 union 来合并

ac65dd3c3ad71188019651395df7f812.png

今天的分享就到这里啦!!~感谢你们的观看,但愿对你们有帮助的话麻烦给个丝滑三连击。(点赞+转发+关注)

一块儿加油,一块儿努力,一块儿秃见成效!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值