MySQL SQL多表查询语句各种连接

一、多表查询

sql 复制代码
#多表查询 笛卡尔积
select * from emp , dept where emp.dept_id = dept.id ;

二、内连接

sql 复制代码
#隐藏式连接
Select emp.name , dept.name from emp,dept where emp.dept_id = dept.id;
​
#起别名
Select e.name, d.name from emp e,dept d where e.dept_id = d.id ;
​
#显示内连接
#查询每一个员工的姓名,及关联的部门的名称
Select e.name , d.name from emp e inner join dept d on e.dept_id = d.id;

三、外连接

sql 复制代码
#1.查询emp表的所有数据,和对应的部门信息(左外连接)
Select e.* , d.name from emp e left outer join dept d on d.id = e.dept_id;
 
#2.查询dept表的所有数据,和对应的员工信息(右外连接)
Select d.* , e.* from emp e right outer join dept d on d.id = e.dept_id;
​
常用左外连接

四、联合查询

sql 复制代码
Select * from emp where id < 5
union
Select * from emp where age = 10;

五、子查询

1.标量子查询

sql 复制代码
#子查询返回的结果是单个值(数字、字符串、日期等),最简单的形式,这种子查询成为标量子查询。
​
#1.查询"销售部"的所有员工信息
#a.查询"销售部"部门id
Select id from dept where name = '销售部';
​
#b.根据销售部id,查询员工信息
Select * from emp where dept_id = 4;
​
#合并
Select * from emp where dept_id = ( select id from dept where name = '销售部' );
​
 
#2.查询在"方东白"入职之后的员工信息
#a.查询方东自的入职日期
Select entrydate from emp where name = '方东自';
​
#b.查询指定入职日期之后入职的员工信息
Select * from emp where entrydate > '2009-09-12';
​
#合并
Select * from emp where entrydate > (select entrydate from emp where name = '方东自');

2.列子查询

sql 复制代码
#1.查询销售部和市场部所有员工信息
#a.查询销售部和市场部的部门id
Select id from dept where name = '销售部' or name = '市场部';
​
#b.根据部门id,查询员工信息
Select * from emp where dept_id in (2,4);
​
#合并
Select * from emp where dept_id in (select id from dept where name = '销售部' or name = '市场部');
​
#2.查询比财务部所有人工资都高的员工信息
#a.查询所有财务部人员工资
Select id from dept where name = '财务部';
Select salary from emp where dept_id = 3;
Select salary from emp where dept_id = (select id from dept where name = '财务部');
​
#b.比财务部所有人工资都高的员工信息
Select * from emp where salary >all (select salary from emp where dept_id = (select id from dept where name = '财务部'));
​
#3.查询比研发部其中任意一人工资高的员工信息
#a.查询研发部所有人工资
Select salary from emp where dept_id = (select id from dept where name = '研发部');
​
#b.比研发部其中任意一人工资高的员工信息
Select * from emp where salary > any (select salary from emp where dept id = (select id from dept where name = '研发部'));

3.行子查询

sql 复制代码
#子查询返回的结果是一行(可以是多列),这种子查询称为行子查询
#常用的操作符:=、<>、IN、NOTIN
​
#1.查询张无忌的薪资及领导相同的员工信息
#a.查询张无忌的薪资及直属领导
Select salary, manager id from emp where name = '张无忌';
​
#b.查询与张无忌的薪资及直属领导相同的员工信息
Select * from emp where salary = 12500 and managerid = 1;
​
Select * from emp where (salary, managerid) = (12500,1);
​
Select * from emp where (salary, managerid) = (select salary,manager id from emp where name = '张无忌');

4.表子查询

sql 复制代码
#子查询返回的结果是一行(可以是多列),这种子查询称为行子查询
#常用的操作符:=、<>、IN、NOTIN
​
#1.查询张无忌的薪资及领导相同的员工信息
#a.查询张无忌的薪资及直属领导
Select salary, manager id from emp where name = '张无忌';
​
#b.查询与张无忌的薪资及直属领导相同的员工信息
Select * from emp where salary = 12500 and managerid = 1;
​
Select * from emp where (salary, managerid) = (12500,1);
​
Select * from emp where (salary, managerid) = (select salary,manager id from emp where name = '张无忌');
相关推荐
i***1324几秒前
SpringCloud实战十三:Gateway之 Spring Cloud Gateway 动态路由
java·spring cloud·gateway
计算机徐师兄2 分钟前
Java基于微信小程序的食堂线上预约点餐系统【附源码、文档说明】
java·微信小程序·食堂线上预约点餐系统小程序·食堂线上预约点餐微信小程序·java食堂线上预约点餐小程序·食堂线上预约点餐小程序·食堂线上预约点餐系统微信小程序
无心水1 小时前
【分布式利器:腾讯TSF】10、TSF故障排查与架构评审实战:Java架构师从救火到防火的生产哲学
java·人工智能·分布式·架构·限流·分布式利器·腾讯tsf
brave_zhao1 小时前
达梦8最终锁阻塞巡检 SQL
数据库
一 乐8 小时前
婚纱摄影网站|基于ssm + vue婚纱摄影网站系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端
Boilermaker19928 小时前
[Java 并发编程] Synchronized 锁升级
java·开发语言
Cherry的跨界思维8 小时前
28、AI测试环境搭建与全栈工具实战:从本地到云平台的完整指南
java·人工智能·vue3·ai测试·ai全栈·测试全栈·ai测试全栈
MM_MS8 小时前
Halcon变量控制类型、数据类型转换、字符串格式化、元组操作
开发语言·人工智能·深度学习·算法·目标检测·计算机视觉·视觉检测
꧁Q༒ོγ꧂9 小时前
LaTeX 语法入门指南
开发语言·latex
njsgcs9 小时前
ue python二次开发启动教程+ 导入fbx到指定文件夹
开发语言·python·unreal engine·ue