300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > MySQL子查询之表子查询

MySQL子查询之表子查询

时间:2024-06-01 05:09:05

相关推荐

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

就是 多个数据 他只要达到一个相同就可以了

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。