Mysql内连接、外连接的区别

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

**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;

在这里插入图片描述

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

最终结果是:

在这里插入图片描述

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

猜你喜欢

转载自blog.csdn.net/weixin_44102466/article/details/90023674
今日推荐