左连接、右连接、交叉连接、全外连接

左连接、右连接、交叉连接、全外连接

第一部分、连接查询

一、内连接


内连接查询操作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的列值。内连接分三种:

1、等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,其查询结果中列出被连接表中的所有列,包括其中的重复列。

2、不等连接: 在连接条件使用除等于运算符以外的其它比较运算符比较被连接的列的列值。这些运算符包括>、>=、<=、<、!>、!<和<>。

3、自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选择列表指出查询结果集合中所包括的列,并删除连接表中的重复列。


二、外连接


返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。


三、交叉连接


交叉连接不带WHERE 子句,它返回被连接的两个表所有数据行的笛卡尔积,返回到结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。例,titles表中有6类图书,而publishers表中有8家出版社,则下列交叉连接检索到的记录数将等于6*8=48行。


第二部分、实例说明

实例

Book表:


Student表:


一、内连接

select *

from [Book] as b,[Student] as s

where b.StudentId=s.StudentId
等价于如下(也可以不要关键字inner,此为系统默认)
select *

from [Book] as b inner join [Student] as s

ON b.StudentId=s.StudentId
结果为:

* 执行过程

相当于内连接的向右连接。以from [Book] inner join [Student]等式右边为基准,即以Student表(等式右表,s表)的s.StudentId为基准,遍历Book表(等式左表,Book表)中与之匹配的b.StudentId,然后拼接返回。结果含有重复的列,b.StudentId和s.StudentId。


* 说明

这与where b.StudentId=s.StudentId或者s.StudentId=b.StudentId位置没有关系。它仅仅代表满足条件而已,不判定谁为基准。以下外连接,交叉连接相同操作。


二、外连接


1、左外连接

* 代码

select *

from [Book] as b left join [Student] as s

ON b.StudentId=s.StudentId
结果


执行过程

即以from [Book] left join [Student]的Book表为基准,即以Book表(b表)的b.StudentId为基准。遍历Student表(s表)中与之匹配的b.StudentId。若b.StudentId含有s.StudentId匹配项,则进行拼接,然后遍历Student表的下一条s.StudentId,当查询完毕则进入下一条b.StudentId。若b.StudentId没有相应s.StudentId匹配项时,则显示左表的项,拼接右表的项显示为NULL。


2、右外连接

* 代码

select *

from [Book] as b right join [Student] as s

ON b.StudentId=s.StudentId
结果

* 执行过程

即以from [Book] right join [Student]的Student表为基准,即以Student表(s表)的s.StudentId为基准。遍历Book表(b表)中与之匹配的s.StudentId。若s.StudentId含有b.StudentId匹配项,则进行拼接,然后遍历Book表的下一条b.StudentId,当查询完毕则进入下一条s.StudentId。若s.StudentId没有相应b.StudentId匹配项时,则显示右表的项,拼接左表的项显示为NULL。


3、全外连接

* 代码

select *

from [Book] as b full outer join [Student] as s

ON b.StudentId=s.StudentId
  结果


* 执行过程

即以from [Book] full outer join [Student]中先以Book表进行左外连接,然后以Student表进行右外连接。

三、交叉连接

* 代码

select *

from [Book] as b CROSS Join [Student] as a

Order by b.BookId
结果


* 执行过程

即是按照Order排序的Id,把要Join的右表无条件拼接过来。这样依次执行,这样这种记录便为两个表的记录的笛卡尔积。


转载地址:http://www.cnblogs.com/LeoTerry/archive/2010/03/26/1696988.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这四种连接方式都是用于在关系型数据库中连接两个或多个表格,但它们的区别在于连接的方式和结果。 1. 交叉连接(CROSS JOIN):也叫笛卡尔积,是将两个或多个表格中的每一行都与另一个表格中的每一行进行组合,从而得到所有可能的组合结果。如果两个表格分别有m和n行,那么交叉连接的结果就会有m x n行。交叉连接通常用于数据挖掘和统计分析中。 2. 内连接(INNER JOIN):也叫等值连接,是将两个表格中的数据根据指定的条件进行匹配,只返回满足条件的行。内连接的结果只包含两个表格中都存在的行。 3. 左外连接(LEFT JOIN):也叫左连接,是将左边的表格中的所有行都返回,而右边的表格只返回满足条件的行。如果右边的表格中没有与左边的表格匹配的行,那么返回的结果中右边的字段将被填充为NULL。 4. 右外连接(RIGHT JOIN):也叫右连接,与左连接相反,是将右边的表格中的所有行都返回,而左边的表格只返回满足条件的行。如果左边的表格中没有与右边的表格匹配的行,那么返回的结果中左边的字段将被填充为NULL。 总的来说,这些连接方式都是用于在关系型数据库中将两个或多个表格连接起来,但它们的区别在于连接的方式和返回的结果。具体使用哪一种连接方式,需要根据实际的业务需求和数据结构来决定。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值