1.内连接
内连接查询的是两张表交集部分的数据。(也就是绿色部分的数据)
内连接的语法分为两种: 隐式内连接、显式内连接。先来学习一下具体的语法结构。
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.外连接
外连接分为两种,分别是:左外连接 和 右外连接。具体的语法结构为:
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条
左外连接方式17条
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;
select name as '员工名称',age '年龄' from emp where salary<5000
union all
select name as '员工名称',age '年龄' from emp where age>50;