图解数据库左连接、右连接、内连接、外连接、全连接的区别

本文详细介绍了数据库中内连接(包括inner join和逗号连接)、外连接(左外连接、左连接、右外连接和右连接)以及全连接(Oracle和MySQL实现)的使用方法,通过实例演示了在A表和B表中查询数据的不同策略。
摘要由CSDN通过智能技术生成

数据库连表方式

  • 内连接 :innerinner join
  • 外连接 :outer join
    • 左外连接 :left outer join
    • 左连接 :left join
    • 右外连接 right outer join
    • 右连接: right join
  • 全连接 full joinunion

准备

现在有2张表,A表和B表,数据和表结构如下
在这里插入图片描述

内连接

内连接查询的是两张表的并集,也就是A表和B表都必须有数据才能查询出来;
在这里插入图片描述

以下三个查询的结果是一样的,针对上面的表数据,能查询出id为1、2、3的数据

-- join
select * from A  join B on A.id = B.id 

-- inner join
select * from A inner join B on A.id = B.id 

-- 逗号的连表方式就是内连接
select * from A , B where A.id = B.id 

左外连接 和 左连接

是以左表为基础,根据ON后给出的两表的条件将两表连接起来。结果会将左表所有的查询信息列出,而右表只列出ON后条件与左表满足的部分。左连接全称为左外连接,是外连接的一种。
在这里插入图片描述

下面2个查询的结果是一样的,针对上面的表数据,能查询出id为1、2、3、4的数据

-- left join
select * from A left join B on  A.id = B.id 

-- left outer join
select * from A left outer join B on  A.id = B.id 

右外连接 和 右连接

是以右表为基础,根据ON后给出的两表的条件将两表连接起来。结果会将右表所有的查询信息列出,而左表只列出ON后条件与右表满足的部分。右连接全称为右外连接,是外连接的一种。
在这里插入图片描述

下面2个查询的结果是一样的,针对上面的表数据,能查询出id为1、2、3的数据

-- right join
select * from A right join B on  A.id = B.id 

-- right outer join
select * from A right outer join B on  A.id = B.id 

全连接

全连接显示两侧表中所有满足检索条件的行。
在这里插入图片描述

oracle的全连接

oracle的全连接查询可以直接用full join,

select * from a full join b on a.id = b.id

mysql的全连接

mysql中没有full join,mysql可以使用union实现全连接;

select * from a left join b on a.id = b.id
union
select * from a right join b on a.id = b.id

评论 17
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

java叶新东老师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值