mysql子查询和多表查询

在这里插入图片描述

mysql对表的理解

mysql中不止是只有磁盘/内存中的表才是真正的表,我们每次筛选出来的都可以是逻辑上的表

子查询

select 查询语句可以嵌套,where字句后可以根select字句,完成子查询。
某些情况下,我们进行查询可能需要很多的句子,而我们也可以通过子查询完成。
在这里插入图片描述

单行子查询

一般搭配where字句使用,where字句后的内容可以是另一个select语句。
在这里插入图片描述
在这里插入图片描述

多行子查询

多行子查询我们就不能使用等号,存在一些字句,进行多行匹配。

in, any, all。

在这里插入图片描述
10号部门的工作岗位不止一个,所以就可能存在多行。
在这里插入图片描述
我们要找到的是emp表中任意一行只要和job中的任意一行匹配就要显示,可以使用in字句,只要匹配,就可以筛选出来。
在这里插入图片描述


在这里插入图片描述
部门30的员工有很多,所以也是多行查询。
在这里插入图片描述

我们要找的是比所以筛选出的sal都高的内容,可以使用all字句代表筛选出的内容比所以内容都大/小。
及比最大的要大,比最小的要小。
可以使用 > < 号来进行匹配。

在这里插入图片描述
在这里插入图片描述


在这里插入图片描述
部门30的员工有很多,所以也是多行查询。
在这里插入图片描述
我们要找的是比任意筛选出的sal都高的内容,可以使用any字句代表筛选出的内容比任意筛选出的内容都大/小。
及比最小的要大/小。
可以使用 > < 号来进行匹配。
在这里插入图片描述

多列子查询

多列子查询可以使用where字句可以进行多列比较的特点进行
在这里插入图片描述
SMITH的部门和岗位是两列,所以是多列子查询,一般来说多列子查询一般只有一行。
在这里插入图片描述
在这里插入图片描述

多表查询

from字句后可以跟多个表,多表查询出的结果是两个表的笛卡尔积。
所谓笛卡尔积,代表第一个表的所有元素与第二个表的所有元素进行排列组合。
在这里插入图片描述
from后跟多个表,可以对多个表进行重命名。

from table_name as new_name…

在这里插入图片描述
在这里插入图片描述
先选出所有部门的平均工资,作为另一个表,与emp表进行多表查询。
在这里插入图片描述
多表中,可以使用点号来选择某个表的某个列。
同时,多表查询需要where子句筛选出某些不符合逻辑的情况。

自连接

多表查询中,两个表可以是同一个表,在这种情况下,我们需要吧表重命名

内连接

内连接就是使用where子句对笛卡尔积进行查询,和之前的一样,不过我们也可以使用其他的语法。

select 字段 from t1 inner join t2 on 条件

使用了on后,就可以不用where子句进行条件筛选。
在这里插入图片描述
在这里插入图片描述

外连接

外连接分为左连接右连接,有时候,我们需要完全显示某个表,如果我们要完全显示左边的表,则可以使用左连接,反之用右连接。
在这里插入图片描述
在这里插入图片描述
左连接和右连接可以互换,如果要左连接,可以以左表作为右连接的第一个表。
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值