SQL中连接表讲解

本文详细介绍了SQL中的连接操作,包括内连接、左连接、右连接、全外连接和交叉连接。重点讲解了右连接的工作原理、语法以及示例,强调了RIGHT JOIN返回右表的所有行,即使在左表中没有匹配的行。接着解释了交叉连接的概念,即两个表的笛卡尔积,并给出了示例。最后提到了自连接在查询分层数据和比较同一表中行的应用,通过示例展示了如何使用自连接查询员工的汇报关系。

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

这节内容有七个知识点[内连接][左连接][右连接][全外连接][交叉连接],我会用小标题的形式向大家展示:在上次中我们讲解了[内连接][左连接],还有[ONWHERE子句],接下来我们来讲解后面的几个知识点:

SQL Server右连接

右连接作用:通过RIGHT JOIN 子句组合来自两个或多个表的数据。               运行原理:RIGHT JOIN 开始从右表中选择数据并与左表中的行 匹配。 RIGHT JOIN返回一个结果集,该结果集包含右表中的所有行,无论是否具有左表中的匹配行。     如果右表中的行没有来自右表的任何匹配行,则结果集中右表的列将使用 NULL 值。 以下是 RIGHT JOIN 的语法:

SELECT

     Select_list

FROM

     T1

RIGHT  JOIN  T2  ON  T1.T1中的字段=T2.T2中的字段

在此语法中, T1 是左表, T2 是右表。

请注意, RIGHT JOIN 和 RIGHT OUTER JOIN 是相同的。 OUTER 关键字是可选的。 下图说明了 RIGHT JOIN 操作:

 

这个图的意思是:通过连接谓词计算(T1.T1中的字段=T2.T2中的字段)为 TRUE 的行才能被查询出来,并且它返回右表中的所有行和左表中的匹配行。如果在左表中找不到匹配的行,则使用 NULL 代替显示。橙色部分表示返回的结果集。

以下语句使用 RIGHT  JOIN 子句查询 student和sc表中的数据:sno,cno,score列中的null列表表明相应的学生没有成绩

 

SQL Server 交叉连接

交叉连接作用:通过CROSS JOIN关键字连接两个或多个不相关的表。

以下是两个表的SQL Server CROSS JOIN 的语法:

SELECT

     Select_list

FROM

     T1

CROSS JOIN T2;

或者

SELECT

select_list

FROM

 T1, T2;

CROSS JOIN 将第一个表(T1)中的每一行与第二个表(T2)中的每一行连接起来。 换句话说,交叉连接返回 两个表中行的笛卡尔积

与INNER JOIN或LEFT JOIN不同,交叉连接不会在连接的表之间建立关系。 假设 T1 表包含三行: 1 , 2 和 3 , T2 表包含三行: A , B 和 C 。 CROSS JOIN 从第一个表(T1)获取一行,然后为第二个表(T2)中的每一行创建一个新行。 然后它对第一个 表(T1)中的下一行执行相同操作,依此类推。 在此图中, CROSS JOIN 总共创建了 9 行。 通常,如果第一个表有 n 行,第二个表有 m 行,则交叉连接 将产生 n x m 行。

下面来展示一下效果:

                                                                                     

 

Student表有12条数据,teacher有3条数据,再用CROSS JOIN关键字连接后有36条数据, 所以交叉连接的结果是 = T1表的条数 乘于 T2表的条数

SQL Server自连接

自连接作用:自联接用于将表连接到自身(同一个表)。

它对于查询分层数据或比较同一个表中的行很有用。 自联接使用内连接或左连接子句。 由于使用自联接的查询引用同一个表,因此表别名用于为查询中的表 分配不同的名称。 请注意,如果在不使用表别名的情况下在查询中多次引用同一个表,则会出现错误。 以下是将表 T 连接到自身的语法:

SELECT  *   FROM  T  t1   [INNER | LEFT] JOIN  T t2  ON T1.T1中的字段=T2.T2中的字段

上面查询语句中两次引用表 T 。表别名 t1 和 t2 用于为 T 表分配不同的名称。

staffs 表存储员工信息,如身份证,名字,姓氏和电子邮件。 它还有一个名为 manager_id 的列,用 于指定直接管理者。 例如,员工 Mireya 向管理员者 Fabiola 汇报工作,因为 Mireya 的 manager_id 列中的值是 Fabiola 。 Fabiola 没有经理,因为它的 manager_id 列是一个 NULL 值。 要获取工作汇报关系,请使用自联接,如以下查询中所示:

在这个例子中,两次引用了 staffs 表:一个是员工的 e ,另一个是管理者的 m 。 连接谓词使用 e.manager_id 和 m.staff_id 列中的值匹配 employee 和 manager 关系。 由于 INNER JOIN 效应, employee 列没有 Fabiola Jackson 。

 

SQL Server全外链接

全外连接作用:FULL OUTER JOIN当左表或右表中存在匹配项时,该命令将返回所有行。

下图说明了 FULL OUTER JOIN 操作:

 

使用 FULL OUTER JOIN 查询 sc和 student表中的数据:

 

 

在此示例中,查询返回有成绩的学生,没有成绩的学生。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值