mysql的 join联合查询的通俗解释

表a 

1
2
3
4
aid adate
1 a1
2 a2
3 a3

表b 

1
2
3
4
bid bdate
1 b1
2 b2
4 b4

两个表a、b相连接,要取出id相同的字段。

1
select  a.aid, a.adate, b.bdate from a inner join b on a.aid = b.bid

这是仅取出匹配的数据。

此时的取出的是:

1
2
1 a1 b1
2 a2 b2

那么left join 指:

1
select a.adi, a.adate, b.bdate from a left join b on a.aid = b.bid

首先取出a表中所有数据,然后再加上与a、b匹配的的数据。

此时的取出的是:

1
2
3
1 a1 b1
2 a2 b2
3 a3 空字符

同样的也有right join

指的是首先取出b表中所有数据,然后再加上与a、b匹配的的数据。

此时的取出的是:

1
2
3
1 a1 b1
2 a2 b2
4 空字符 b4

LEFT JOIN 或 LEFT OUTER JOIN。

左向外联接的结果集包括 LEFT OUTER 子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值。

原文地址:https://www.cnblogs.com/dongzhuangdian/p/5935926.html