自然左右外联接的区别

本文详细解释了SQL中外联接的概念及应用,包括左联接、右联接和全联接等类型,并通过具体实例展示了不同联接方式的效果,有助于理解何时使用何种联接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在 FROM 子句中指定外联接时,可以由下列几组关键字中的一组指定:

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

RIGHT JOIN 或 RIGHT OUTER JOIN。
右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。

FULL JOIN 或 FULL OUTER JOIN。
完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。

仅当至少有一个同属于两表的行符合联接条件时,内联接才返回行。内联接消除与另一个表中的任何行不匹配的行。而外联接会返回 FROM 子句中提到的至少一个表或视图的所有行,只要这些行符合任何 WHERE 或 HAVING 搜索条件。将检索通过左向外联接引用的左表的所有行,以及通过右向外联接引用的右表的所有行。完整外部联接中两个表的所有行都将返回。

 

现在假设有学生表,学生课程分数表

 

完整文字 c_id s_id subject acc
编辑 删除 11语文98
编辑 删除 21数学90
编辑 删除 32英语2

 

完整文字 ids name gender
编辑 删除 1小明
编辑 删除 2小华
编辑 删除 3小兰
编辑 删除 4小军

 

SELECT *
FROM acc
LEFT JOIN student ON s_id = ids
LIMIT 0 , 30
 
执行结果:
 
c_id s_id subject acc ids name gender
11语文981小明
21数学901小明
32英语22小华

 

 

SELECT *
FROM acc
RIGHT JOIN student ON s_id = ids
LIMIT 0 , 30
 
结果
 
c_id s_id subject acc ids name gender
11语文981小明
21数学901小明
32英语22小华
NULLNULLNULLNULL3小兰
NULLNULLNULLNULL4小军
 
 
得出以下结论: 所谓左表也就是你from的表,右表就是你join的表
leftjion 的意思就是以左表的纪录为准,反之rightjoin
还想说说啥时候用,也就是说,俩个表的数据不对称的时候用,
可能基础了点,但是越基础越重要么
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值