mysql内连接和外连接的区别_内连接、外连接的区别

2022-10-03 08:36:14

先来看一下,内连接的语法:

SELECT  XXX FROM XXX INNER JOIN XXX ON XXX;

这里 INNER 可以省略,在上一篇博客中我们对于笛卡尔积现象的研究中(http://www.cnblogs.com/cdf-opensource-007/p/6507678.html)用到的就是内连接,但这并不能说明笛卡尔积算法只是适用于内连接,笛卡尔积算法针对的是表之间数据行的匹配次数,跟内连接还是外连接无关,至于查询结果与你的查询条件有关系,在本文中将对这一算法和内、外连接的区别加以说明。

内连接指的是把表连接时表与表之间匹配的数据行查询出来,就是两张表之间数据行匹配时,要同时满足ON语句后面的条件才行。

左连接和右连接,又叫左外连接和右外连接。

我们来看一下左连接的语法

SELECT XXX FROM XXX LEFT OUTER JOIN XXX ON XXX

左连接的意思是,无论是否符合ON语句后面的表连接条件都会把左边那张表的记录全部查询出来,右边的那张表只匹配符合条件的数据行。右连接则与之相反(这里同样OUTER 可以省略)。

下面我们以左连接为例,来看一下这个匹配的过程。有两张表商品表goods和订单表order_table。

SELECT * FROM goods g LEFT JOIN order_table ot ON g.id = ot.goods_id

5a24484d2fab129e0b87405ca9a79f4c.png

9a7770a09fd28cdafccb502977ffd092.png

数据行间的匹配以此类推。

最终结果是:

eda4cbd1f0d7f824d0ba69058a636643.png

蓝线部分表示两张表数据行之间的匹配符合 ON g.id = ot.goods_id,虚线则表示不符合匹配条件,我们看到步骤二中,即使左边的表跟右边的表没有一行数据能够匹配的,左边的表的数据行还是会出现在连接之后的临时表中,而这时右边的数据行的内容用Null填充。根据分析我们还可以看到,数据行之间匹配的次数还是符合笛卡尔积。

  • 作者:weixin_39636696
  • 原文链接:https://blog.csdn.net/weixin_39636696/article/details/111257612
    更新时间:2022-10-03 08:36:14