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

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表中找不到

猜你喜欢

转载自blog.csdn.net/qq_36437446/article/details/82562462