SQL:左连接,右连接是啥概念啊

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL:左连接,右连接是啥概念啊相关的知识,希望对你有一定的参考价值。

参考技术A

SQL中左连接和右连接都属于外连接。

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

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

举例:要查询所有学生的选课情况,包括已经选课的和还没有选课的学生,查询语句为SELECT学生表.学号,姓名,班级,课程号,成绩FROM学生表LEFTOUTERJOIN选课表ON学生表.学号=选课表.学号,左外连接查询中左端表中的所有元组的信息都得到了保留。

扩展资料

连接查询是关系数据库中最主要的查询,主要包括内连接、外连接和交叉连接等。联接条件可在FROM或WHERE子句中指定,建议在FROM子句中指定联接条件。WHERE和HAVING子句也可以包含搜索条件,以进一步筛选联接条件所选的行。  

内连接是INNERJOIN简写成JOIN,是典型的联接运算,使用像= 或<>之类的比较运算符。包括相等联接和自然联接。内联接使用比较运算符根据每个表共有的列的值匹配两个表中的行。例如,检索students和courses表中学生标识号相同的所有行。  

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

交叉联接返回左表中的所有行,左表中的每一行与右表中的所有行组合。交叉联接也称作笛卡尔积。FROM子句中的表或视图可通过内联接或完整外部联接按任意顺序指定;但是,用左或右向外联接指定表或视图时,表或视图的顺序很重要。

参考资料 百度百科-连接查询

左连接和右连接:因为我可以反转操作数,实际区别是啥?

【中文标题】左连接和右连接:因为我可以反转操作数,实际区别是啥?【英文标题】:left and right joins: what is the actual difference since I can invert the operands?左连接和右连接:因为我可以反转操作数,实际区别是什么? 【发布时间】:2012-03-24 16:44:41 【问题描述】:

我正在学习 SQL,我根本没有做任何测试,所以我很抱歉我的愚蠢问题。 显然(在我的猜测中,LOL)LEFT 和 RIGHT 连接可以等效地反转表(操作数)。是这样吗?

如果是,那为什么我更喜欢写这个:

SELECT * FROM aaa LEFT OUTER JOIN bbb ON aaa.x = bbb.x

而不是这个:

SELECT * FROM bbb RIGHT OUTER JOIN aaa ON aaa.x = bbb.x

【问题讨论】:

ON 子句中的顺序无关紧要——重要的是外连接的内容和方式(左、右、全)。就个人而言,我看不到RIGHT 的用途,我总是使用LEFT... 我知道 a=b 和 b=a 没有区别,我说的是连接操作数 只要表的操作数颠倒,它们是等价的。无论 OUTER JOIN'd 是什么,都变成可选的(意思是,如果没有定义关系的数据,则该引用中的任何列都可以是 NULL)。 NATURAL JOIN 的原因相同——ANSI 并不完美,它有助于指示方向。另外,不能有 LEFT 没有 RIGHT。这就像说你相信撒旦,但不相信上帝...... 是的,但是为什么需要方向,因为我可以反转表名?例如 >= 和 = b === b 【参考方案1】:

我发现最好的方法是看看下面的图片清除你的疑问

原始答案:How do I decide when to use right joins/left joins or inner joins Or how to determine which table is on which side?

【讨论】:

是的,但这不能回答我的问题:选择图像的第一个左上角示例 (SELECT * FROM aaa LEFT JOIN bbb ON aaa.x=bbb.x) 相当于 (SELECT * FROM bbb RIGHT JOIN aaa ON aaa.x=bbb.x) 与否? 所以...再次,LEFT 和 RIGHT 之间的实际区别是什么,如果有的话,因为我可以反转表名? @toPeerOrNotToPeer - 这取决于您的兴趣,但您编写它的方式并没有任何区别 而在更复杂的查询中,左右可以使结果有所不同,或者在任何情况下都可以为程序员提供方便? @toPeerOrNotToPeer - 正如我所说,这取决于您的兴趣..您必须选择要使用的。【参考方案2】:

在许多情况下,您必须连接超过 2 个表 - 例如需要来自超过 2 个表的数据的存储过程、视图或查询 - 。在这些情况下,您需要为查询选择一个起点 - 在本例中是一个表。

在其中一个表“aaa”将适合开始查询,在其他“bbb”会更好。

这就是存在LEFTRIGHT 连接的原因。

【讨论】:

以上是关于SQL:左连接,右连接是啥概念啊的主要内容,如果未能解决你的问题,请参考以下文章

sql左连接 右连接 内连接 外连接都是啥

左连接和右连接:因为我可以反转操作数,实际区别是啥?

SQL——左连接(Left join)右连接(Right join)内连接(Inner join)

内连接,外链接(左连接右连接全连接),交叉连接大总结+附SQL JOINS图解[转]

数据库操作中,左连接,右连接是啥意思,举例说明

SQL中的左连接与右连接,内连接有啥区别