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

原创 2013年12月04日 10:19:32

文章摘抄至http://www.cnblogs.com/LeoTerry/archive/2010/03/26/1696988.html

 

第一部分、连接查询

一、内连接

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

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.StudentIds.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的右表无条件拼接过来。这样依次执行,这样这种记录便为两个表的记录的笛卡尔积。

 

 

 

 

 

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

第一部分、连接查询 一、内连接 内连接查询操作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的列值。内连接分三种: 1、等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,...
  • runming56
  • runming56
  • 2013年10月11日 19:54
  • 465

内连接,外连接,左连接,右连接,全连接,内连接,交叉连接,自连接

(一) 内连接内连接,inner join,join 查询操作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的 列值。内连接分三种: 1.等值连接2.不等值连接3.自然连接(二) 外连接  ...
  • zdwzzu2006
  • zdwzzu2006
  • 2011年06月26日 16:57
  • 1659

Oracle内连接、左外连接、右外连接、全外连接

表TESTA,TESTB,TESTC,各有A, B两列 A B 001 10A 002 20A A B 001 10B 00...
  • futdktyx
  • futdktyx
  • 2013年12月06日 13:46
  • 1653

SQL的左连接 右连接 全连接 内连接 交叉连接

关于sql语句中的连接(join)关键字,是较为常用而又不太容易理解的关键字,下面这个例子给出了一个简单的解释 --建表table1,table2: create table table1(id i...
  • love_java_cc
  • love_java_cc
  • 2016年08月17日 11:35
  • 244

SQL内连接、左外链接、右外连接、交叉链接区别

SQL内连接、左外链接、右外连接、交叉链接区别                                                                — —你可以做到任何事,...
  • chajinglong
  • chajinglong
  • 2016年08月12日 20:40
  • 907

内连接、左外连接、右外连接、交叉连接及其区别

首先建立两张表A、B。 表A: Aid:int类型,无符号递增,主键 name:varchar类型 表B: Bid:int类型,无符号递增,主键 name:varchar类型 age:int类型 ...
  • xukun5137
  • xukun5137
  • 2016年06月20日 19:49
  • 2254

内连接,外链接(左连接、右连接、全连接),交叉连接大总结

1.什么是连接查询呢?     概念:根据两个表或多个表的列之间的关系,从这些表中查询数据。     目的:实现多个表查询操作。 2.分类: 首先划分一下,连接分为三种:内...
  • basycia
  • basycia
  • 2016年08月14日 20:17
  • 3499

数据表连接(左连接,右连接,内连接,笛卡尔)

--查询分析器中执行:--建表table1,table2:create table table1(id int,name varchar(10))create table table2(id int,...
  • simonhehe
  • simonhehe
  • 2007年06月17日 14:31
  • 4672

sql查询之左连接,右连接,内连接以及全外连接的使用(测试常见面试题欧)

sql查询之左连接,右连接,内连接以及全外连接的使用(测试常见面试题欧)...
  • zx_water
  • zx_water
  • 2017年04月11日 17:58
  • 980

表的内连接、外连接(左连接与右连接)

听同学说有校招笔试考到这个概念,一般没有专门学习数据库的话对这个都不是很了解,但是其实很简单,看到一篇博客对这个概念解释的很清楚,故而转载。  有两个表A和表B。   ...
  • u012909091
  • u012909091
  • 2015年09月15日 09:37
  • 3021
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:左连接、右连接、交叉连接、全外连接
举报原因:
原因补充:

(最多只允许输入30个字)