MySQL子查询之表子查询

表子查询 是只 子查询得到的数据 是多行多列的 就像一张单独的数据表
我们这里有一张staff 员工表
在这里插入图片描述

还有一张 department 部门表
在这里插入图片描述
可以看出 两张表是外键关系 staff 员工表用departmentid为外键 存下来 对应部门表department 的id

然后 这里我们通过一个需求 了解表子查询

我们要找出年龄大于30的用户 并找出他们的部门

我们先来实现查询年龄大于三十的用户

select * from staff where age > 30;

运行结果如下
在这里插入图片描述
此时 我们查出了 两个年龄 age字段大于三十的员工 分别是黄飞鸿和李如

然后我们一步到位 实现上面的需求 编写sql如下

select * from (select * from staff where age > 30) e left join department d on e.departmentid = d.id;

这里 我们将子查询 查到的多行多列的数据 作为一张暂时的存储数据的表 然后用他里面的数据跟部门表去连表查询

这就是表子查询比较常见的一种形式 用sql查询出一个表类型 多行多列的数据 作为暂时的数据存储表 去和别的表去连表查询

还有一种用法

我们查询 查询和黄飞鸿或李如 状态字段和年龄相同的数据
我们直接这样写

select * from staff where (status,age) in (select status,age from staff where name = "黄飞鸿" or "李如");

在这里插入图片描述
因为 表子查询返回的是多列的数据 就不能直接这样写等于号了 这里我们用了 in
就是 多个数据 他只要达到一个相同就可以了

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值