数据库连表方式

    内连接 :inner 、inner join
    外连接 :outer join
        左外连接 :left outer join
        左连接 :left join
        右外连接 right outer join
        右连接: right join
    全连接 full join 、union

准备

现在有2张表,A表和B表,数据和表结构如下


在这里插入图片描述
内连接



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

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

 

 

 


左外连接 和 左连接

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

 

 


在这里插入图片描述

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

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


在这里插入图片描述

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


全连接

全连接显示两侧表中所有满足检索条件的行。


在这里插入图片描述

oracle的全连接

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



mysql的全连接

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