详解数据库表之间的连接方式

本文详细介绍了SQL中的内联结和外联结的概念及其使用方法。内联结用于查询两张表中共有的数据,而外联结则能展示即使在一张表中不存在匹配项的数据。文章通过具体例子展示了不同连接方式的应用场景。

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

1.内联结也就是在两张表的相同属性上做的等值连接即自然连接,下面用简明的图例进行说明

上面是我们用到两张表,可以看到在两张表中的相同属性为TNO 即为教师的职工号,那么此时如果我们想要对李诚老师的课程进行查询就涉及到了内联结,内联结的两种写法是:

-- 第一种写法
select cname
from table1 inner join table2
on table1.tno=table2.tno;


-- 第二种写法
select cname
from table1 and table2
where table1.tno=table2.tno;

第一种写法,是标SQL的写法, from 语句中将需要进行等值连接的表 写在 inner join两侧,on 语句表示进行等值连接的字段

第二种写法,是比较常见的写法,但是当将内联结和where语句进行条件选择的时候,可能会分不清哪个是连接字段,那可是作为选择的字段。

 

 

2.关于外连结 OUTER JOIN

外连结也是通过on子句的联结键将两表进行联结,并从两张表中同时选取相应的列。再次将用到的表贴出来

ShopProduct表

Product表

select SP.SHOP_ID,SP.SHOP_NAME,SP.PRODUCT_ID,p.PRODUCT_NAME
from SHOPPRODUCT  sp RIGHT OUTER JOIN PRODUCT  p
on SP.PRODUCT_ID=p.PRODUCT_ID;

对应结果为

为什么会出现这样的结果呢?并且表的左下角还有两行NULL 值

首先看一下,多出来的两行数据是高压锅和圆珠笔,这两行数据表示,高压锅和圆珠笔这两种商品并没有在任何商店中出现过,对于外连结来说,只要数据存在于某一张表当中,就能取出来,而内联结只能取出同时存在于两张表中的数据

那么,那张表是主表呢?最终结果会包含主表内所有的数据

对于rightouter join这种来说,写在右侧的表是主表

对于left outer join这种来说,写在左侧的表是主表

这就可以解释NULL的出现,因为对于高压锅和圆珠笔的销售信息在ShopProduct表中找不到

评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

巴塞罗那的风

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值