表子查询 是只 子查询得到的数据 是多行多列的 就像一张单独的数据表 我们这里有一张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 就是 多个数据 他只要达到一个相同就可以了
|