二十一、MySQL(多表)内连接、外连接、自连接实现

1、多表查询

(1)基础概念:

二十一、MySQL(多表)内连接、外连接、自连接实现_第1张图片

 (2)多表查询的分类:

二十一、MySQL(多表)内连接、外连接、自连接实现_第2张图片

2、内连接

(1)基础概念: 

二十一、MySQL(多表)内连接、外连接、自连接实现_第3张图片

(2)隐式内连接:

基础语法:

select 表1.name,表2.name from 表1,表2 where 表1.外键=表2.被链接的字段;

实际操作:

# (1)查询每一个员工的姓名,以及关联的部门名称--隐式查询
select emp.name,course.name from emp,course where emp.number=course.id;

二十一、MySQL(多表)内连接、外连接、自连接实现_第4张图片

(3)显式内连接:

基础语法:

select 表1.name,表2.name from 表1 inner join 表2 on 表1.外键 =表2.被链接的字段;

实际操作:

# (2)查询每一条员工的姓名,以及关联的部门名称--显式查询
# inner join ... on ...
select emp.name,course.name from emp inner join course on emp.number =course.id;

(4)区别:

        相对而言,隐式连接好理解好书写,语法简单,担心的点较少。但是显式连接可以减少字段的扫描,有更快的执行速度。这种速度优势在3张或更多表连接时比较明显。

3、外连接

(1)基础概念:

二十一、MySQL(多表)内连接、外连接、自连接实现_第5张图片

 二十一、MySQL(多表)内连接、外连接、自连接实现_第6张图片

二十一、MySQL(多表)内连接、外连接、自连接实现_第7张图片

 (2)左外连接:

-- 外连接演示:
-- 1、查询emp表的所有数据,和对应的部门信息(左外连接):
-- 表结构:emp、course
-- 左外连接,会显示左表中的每一条数据
select emp.*,course.name from emp left outer join course on emp.number=course.id;

二十一、MySQL(多表)内连接、外连接、自连接实现_第8张图片

(3)右外连接:

-- 2、查询course表的所有数据,和对应的员工信息(右外连接):
-- 表结构:emp、course
-- 右外连接,会显式左表中的每一条数据
select course.*,emp.* from emp right outer join course on emp.number=course.id;

二十一、MySQL(多表)内连接、外连接、自连接实现_第9张图片

 4、自连接

(1)基础概念:

自连接顾名思义,就是自己链接自己,基础语法如下:

select 字段列表 from 表A 别名A join 表A 别名B on 条件……;

(2)原表格:

二十一、MySQL(多表)内连接、外连接、自连接实现_第10张图片

 (3)实际操作:

-- 自链接演示
# 一张表自己连接自己
# select 字段列表 from 表A 别名A join 表A 别名B on 条件……;
# 查询员工及其所属领导的名字
select e1.name as '员工',e2.name as '领导' from emp e1 join emp e2 on e1.manager=e2.id;

二十一、MySQL(多表)内连接、外连接、自连接实现_第11张图片

你可能感兴趣的:(MYSQL,mysql,数据库,sql)