话不多说,先上个对于各种join情况的总结图:

例如有如下关系的数据:

1、inner join

select * from Table_a
join Table_b on Table_a.id_a = Table_b.id_b
2.1、full outer join等于full join

select * from Table_a full join Table_b on Table_a.id_a = Table_b.id_b

2.2、full outer join but a.Key is null or b.Key is null

select * from Table_a full outer join Table_b on Table_a.id_a = Table_b.id_b where Table_a.id_a is null or Table_b.id_b is null

3.1、left outer join等于left join

select * from Table_a left join Table_b on Table_a.id_a = Table_b.id_b

3.2、left outer join but b.Key is null

select * from Table_a
left outer join Table_b on Table_a.id_a = Table_b.id_b
where Table_b.id_b is null
4、笛卡尔积
select * from Table_a ,Table_b

原文链接:

本文深入解析SQL中的Join操作,包括Inner Join、Full Outer Join、Left Outer Join和笛卡尔积的概念及使用场景,通过实例帮助理解不同Join类型的差异。
2327

被折叠的 条评论
为什么被折叠?



