left join \ right join \ inner join 的区别

1 概念

left join (左联接):返回包括左表中的所有记录右表中联结字段相等的记录
right join (右联接):返回包括右表中的所有记录左表中联结字段相等的记录
inner join (等值连接):只返回两个表中联结字段相等的行
 

2 例子

 

 

2.1 left join

select * from A left join B on A.aID = B.bID

left join 是以 A 表的记录为基础的,A可以看成左表,B可以看成右表,left join是以左表为准的
换句话说,左表 (A) 的记录将会全部表示出来,而右表 (B) 只会显示符合搜索条件的记录 (例子中为: A.aID = B.bID),
B 表记录不足的地方均为 NULL。
 
 

2.2 right join

select * from A right join B on A.aID = B.bID

 和 left join 的结果刚好相反,这次是以右表 (B) 为基础的,A 表不足的地方用 NULL 填充.

 
 

2.2 inner join 

select * from A innerjoin B on A.aID = B.bID

 只显示出了 A.aID = B.bID 的记录,这说明 inner join 并不以谁为基础它只显示符合条件的记录

 

posted @ 2022-04-19 11:36  磨难可以选择  阅读(100)  评论(0)    收藏  举报