表:
test1
id name
1 aaa
2 bbb
3 ccc
test2
id name
1 eee
1 fff
3 ggg
左连接也称左外连接(右连接同理):将左表的所有记录列出,右表中只要符合on条件的,与左表记录相拼合,不符合条件的,填以null值。
例:select t1.*,t2.* from test1 t1 left join test2 t2 on t1.id=t2.id
结果:
id name id name
1 aaa 1 eee
1 aaa 1 fff
3 ccc 3 ggg
2 bbb null null
内连接:根据左连接来说,不会将左表的所有记录列出,不符合条件的,不填null值,只找符合条件的。
例:select t1.*,t2.* from test1 t1 inner join test2 t2 on t1.id=t2.id
结果:
id name id name
1 aaa 1 eee
1 aaa 1 fff
3 ccc 3 ggg
全连接:左连接+右连接,把重复的合并。
例:select t1.*,t2.* from test1 t1 full join test2 t2 on t1.id=t2.id
结果:
id name id name
1 aaa 1 eee
1 aaa 1 fff
3 ccc 3 ggg
2 bbb null null
多表联查:笛卡尔积
例:select t1.*,t2.* from test1 t1,test2 t2
结果:
id name id name
1 aaa 1 eee
1 aaa 1 fff
1 aaa 3 ggg
2 bbb 1 eee
2 bbb 1 fff
2 bbb 3 ggg
3 ccc 1 eee
3 ccc 1 fff
3 ccc 3 ggg
test1
id name
1 aaa
2 bbb
3 ccc
test2
id name
1 eee
1 fff
3 ggg
左连接也称左外连接(右连接同理):将左表的所有记录列出,右表中只要符合on条件的,与左表记录相拼合,不符合条件的,填以null值。
例:select t1.*,t2.* from test1 t1 left join test2 t2 on t1.id=t2.id
结果:
id name id name
1 aaa 1 eee
1 aaa 1 fff
3 ccc 3 ggg
2 bbb null null
内连接:根据左连接来说,不会将左表的所有记录列出,不符合条件的,不填null值,只找符合条件的。
例:select t1.*,t2.* from test1 t1 inner join test2 t2 on t1.id=t2.id
结果:
id name id name
1 aaa 1 eee
1 aaa 1 fff
3 ccc 3 ggg
全连接:左连接+右连接,把重复的合并。
例:select t1.*,t2.* from test1 t1 full join test2 t2 on t1.id=t2.id
结果:
id name id name
1 aaa 1 eee
1 aaa 1 fff
3 ccc 3 ggg
2 bbb null null
多表联查:笛卡尔积
例:select t1.*,t2.* from test1 t1,test2 t2
结果:
id name id name
1 aaa 1 eee
1 aaa 1 fff
1 aaa 3 ggg
2 bbb 1 eee
2 bbb 1 fff
2 bbb 3 ggg
3 ccc 1 eee
3 ccc 1 fff
3 ccc 3 ggg
本文详细介绍了SQL中的不同连接类型,包括左连接(左外连接)、内连接和全连接的概念及用法,并通过实例展示了如何使用这些连接来组合不同的数据表。
364

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



