SQL 链接表

本文详细介绍了SQL中的各种连接操作,包括内连接、左连接、右连接、交叉连接和自连接,并通过实例练习解释了它们的工作原理和查询结果。例如,内连接返回两个表中匹配的行,左连接返回左表的所有行和右表的匹配行,而右连接则反之。交叉连接会产生两个表的笛卡尔积,自连接则用于同一个表的内部连接,常用于查询分层数据或比较同一表中的行。

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

 

 

 

 

1:内连接

语法:

SELECT

字段1,字段2,字段3……

FROM

表格1

INNER JOIN 表格2 ON 表格1.要和表格2相连的字段=表格2.要和表格1相连的字段;

下图为内连接表1和表2的关系图

 

      若上图没看懂,没关系,我们可以通过下面的练习来理解内连接的原理;

练习1:使用内连接对学生表以及成绩表进行连接

select * 

from SC c

inner join Student s on s.Sid=c.Sid

结果如下:

 

由上图可以知道,(使用内连接对学生表以及成绩表进行连接)查询到的结果为18条数据。在结果中,(左边)成绩的数据为18条,(右边)学生表的数据也为18条,但在前面我们可以知道学生表的数据为8条,成绩表中的数据为18条,这是为什么呢?

回到用内连接对学生表(Student)以及成绩表(SC)进行连接的语句中

select * 

from SC c

inner join Student s on s.Sid=c.Sid

在语句中,成绩表和学生表连接的条件是:s.Sid=c.Sid

也就是说查出 成绩表中的学号字段 等于 学生表中的学号字段 的数据

由查询的结果可以知道成绩表和学生表相等的学号为:01020304050607

  • 成绩表查询出来的数据为18
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值