沈柯成,发外链工具,如何去眼角细纹
实际的项目,存在多张表的关联关系。不可能在一张表里面就能检索出所有数据。如果没有表连接的话,那么我们就需要非常多的操作。比如需要从a表找出限制性的条件来从b表中检索数据。不但需要分多表来操作,而且效率也不高。比如书中的例子:
这个sql语句返回2,也就是姓名为mike 的客户的fid值为2,这样就可以到t_order中检索fcustomerid等于2 的记录:
下面我们详细来看看表连接。表连接有多种不同的类型,有交叉连接(cross join)、内连接(inner join)、外连接(outter join)。
(1)内连接(inner join):内连接组合两张表,并且只获取满足两表连接条件的数据。
注:在大多数数据库系统中,inner join中的inner是可选的,inner join 是默认的连接方式。
在使用表连接的时候可以不局限于只连接两张表,因为有很多情况下需要联系许多表。例如,t_order表同时还需要连接t_customer和t_ordertype两张表才能检索到所需要的信息,编写如下sql语句即可:
(2)交叉连接(cross join):交叉连接所有涉及的表中的所有记录都包含在结果集中。可以采用两种方式来定义交叉连接,分别是隐式和显式的连接。
下面看看隐式的例子:
使用显式的连接则需要使用cross join,例子如下:
(3)外连接(outter join):内部连接只获取满足连接条件的数据,而对于外部连接来说,主要是解决这样的一种场景。满足条件的数据检索出来,这个没有疑问,外部连接还会检索另一部分数据,那就是将不满足条件的数据以null来填充。先来看一下外连接的分类:左外部连接(left outer join)、右外部连接(right outer join)和全外部连接(fullouter join)。
i、左外部连接(left outer join):前头也说了,将不满足条件的数据以null来填充。那么具体是哪些需要以null来填充呢,对于左外连接来说的话,连接条件当中,如果出现满足条件的左表的数据在右表中没有相应匹配时,需要把相应的右表字段填充null值。也就是说左外部连接的主体是左表,右表来配合。
注:如果使用左外部连接的话,通过where语句能过滤其中不符合的数据
ii、右外部连接(right outer join):右外部连接与左外连部接相反,将会被填充null值的是左表的字段。也就是说右外部连接的主体是右表,左表来配合。
注:同左外连接一样,可以使用where语句进行过滤
iii、全外部连接(fullouter join):全外部连接是左外部连接和右外部连接的合集。也就是既包括左外部连接的结果集,也包括右外部连接的结果集。
其结果相当于:
如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复
数据库SQL---数据库、基本表、视图、索引的定义、修改、删除
在 Azure CentOS VM 中配置 SQL Server 2019 AG - (上)
在 Azure CentOS VM 中配置 SQL Server 2019 AG - (下)
网友评论