sql server 什么是全外连接,左外连接,右外连接,它们的区别又是什么?
展开全部
全外连接就是左外连接和右外连接的结合。
左外连接和右外连接的区别如下:
1、数据集合上的区别
(1)左外连接:是A与B的交集,然后连接A的所有数据。
(2)右外连接:是A与B的交集,然后连接B的所有数据。
2、计算方法上的区别
(1)左外连接:计算方法是,A左连接B记录=表3的公用记录集C +表A的记录集A1。
(2)右外连接:计算方法是,A右连接B记录=图3公共部分记录集C +表B记录集B1。
3、语法上的区别
(1)左外连接:SELECT * FROM aleft OUTER JOIN bON a.`ageId` = b.`id`。
(2)右外连接:SELECT * FROM aright OUTER JOIN bON a.`ageId` = b.`id`。
展开全部
简单来讲,随便来个例子:
A表 B表
id name id name
1 a 1 b
2 b 3 c
4 c
左外连接就是以左表为准,去匹配右表,左表有多少条数据,结果就是多少条数据
select * from A left join B on A.id=B.id
id name id name
1 a 1 b
2 b null null
4 c null null
右外连接就是与左外连接反之,以右表为准,去匹配左表,右表有多少条数据,结果就是多少条数据
select * from A right join B on A.id=B.id
id name id name
1 a 1 b
null null 3 c
全外连接数据条数不一定,相当与是左外连接 和右外连接 的综合
select * from A full join B on A.id=B.id
id name id name
1 a 1 b
2 b null null
null null 3 c
4 c null null
希望你能明白!!!
A表 B表
id name id name
1 a 1 b
2 b 3 c
4 c
左外连接就是以左表为准,去匹配右表,左表有多少条数据,结果就是多少条数据
select * from A left join B on A.id=B.id
id name id name
1 a 1 b
2 b null null
4 c null null
右外连接就是与左外连接反之,以右表为准,去匹配左表,右表有多少条数据,结果就是多少条数据
select * from A right join B on A.id=B.id
id name id name
1 a 1 b
null null 3 c
全外连接数据条数不一定,相当与是左外连接 和右外连接 的综合
select * from A full join B on A.id=B.id
id name id name
1 a 1 b
2 b null null
null null 3 c
4 c null null
希望你能明白!!!
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
呃
inner join
left join
right join
cross join (交叉连接)
这个还是查下相关资料吧,敲起来太费劲啊
inner join
left join
right join
cross join (交叉连接)
这个还是查下相关资料吧,敲起来太费劲啊
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询