10.MySql内连接、外连接、自连接、联合查询union

0 阅读3分钟

1.内连接

内连接查询的是两张表交集部分的数据。(也就是绿色部分的数据) image.png

内连接的语法分为两种: 隐式内连接、显式内连接。先来学习一下具体的语法结构。

1). 隐式内连接 SELECT 字段列表 FROM 表1 , 表2 WHERE 条件 ... ;

2). 显式内连接 SELECT 字段列表 FROM 表1 [ INNER ] JOIN 表2 ON 连接条件 ... ;

select emp.name , dept.name from emp , dept where emp.dept_id = dept.id ;

-- 为每一张表起别名,简化SQL编写

select e.name,d.name from emp e , dept d where e.dept_id = d.id;

B. 查询每一个员工的姓名 , 及关联的部门的名称 (显式内连接实现)

select e.name, d.name from emp e inner join dept d on e.dept_id = d.id;

-- 为每一张表起别名,简化SQL编写

select e.name, d.name from emp e join dept d on e.dept_id = d.id;

2.外连接

外连接分为两种,分别是:左外连接 和 右外连接。具体的语法结构为:

image.png

1). 左外连接 SELECT 字段列表 FROM 表1 LEFT [ OUTER ] JOIN 表2 ON 条件 ... ; 左外连接相当于查询表1(左表)的所有数据,当然也包含表1和表2交集部分的数据。

2). 右外连接SELECT 字段列表 FROM 表1 RIGHT [ OUTER ] JOIN 表2 ON 条件 ... ; 右外连接相当于查询表2(右表)的所有数据,当然也包含表1和表2交集部分的数据。

A. 查询emp表的所有数据, 和对应的部门信息

select e.*, d.name from emp e left outer join dept d on e.dept_id = d.id;

select e.*, d.name from emp e left join dept d on e.dept_id = d.id;

B. 查询dept表的所有数据, 和对应的员工信息(右外连接)

select e.*,d.* from emp e right join dept d on e.dept_id = d.id;

左外连接和右外连接是可以相互替换的,只需要调整在连接查询时SQL中,表结构的先后顺序就可以了。而我们在日常开发使用时,更偏向于左外连接。

3.自连接

自连接查询,顾名思义,就是自己连接自己,也就是把一张表连接查询多次。我们先来学习一下自连接的查询语法: SELECT 字段列表 FROM 表A 别名A JOIN 表A 别名B ON 条件 ... ;而对于自连接查询,可以是内连接查询,也可以是外连接查询。

A. 查询员工 及其 所属领导的名字

-- 自连接查询 内连接方式 如果领导和员工无法对应 就不会查出来了
select  a.name as '员工名称',b.name as '领导名称'from emp a join emp b on a.managerid = b.id;
-- 左外连接方式 金庸领导是null 也可以查出来
select a.name as '员工名称',b.name as '领导名称' from emp a left join emp b on a.managerid = b.id;

内连接方式16条 image.png

左外连接方式17条 image.png

4.联合查询

对于union查询,就是把多次查询的结果合并起来,形成一个新的查询结果集。 union all 会将全部的数据直接合并在一起,union 会对合并之后的数据去重, 对于联合查询的多张表的列数必须保持一致,字段类型也需要保持一致。

语法: SELECT 字段列表 FROM 表A ... UNION [ ALL ] SELECT 字段列表 FROM 表B ....;

A. 将薪资低于 5000 的员工 , 和 年龄大于 50 岁的员工全部查询出来

select name as '员工名称',age '年龄' from emp where salary<5000
union
select name as '员工名称',age '年龄' from emp where age>50;

image.png

select name as '员工名称',age '年龄' from emp where salary<5000
union all
select name as '员工名称',age '年龄' from emp where age>50;

image.png