左连接右边连接

上一篇 / 下一篇  2013-07-21 17:05:40 / 个人分类:数据库

  •  
  • 左连接显示左边全部的和右边与左边相同的
  • 右连接显示右边全部的和左边与右边相同的
  •  
  • 实例

Book表:Student表:

一、内连接

select*

from[Book]asb,[Student]ass

whereb.StudentId=s.StudentId

*        等价于如下(也可以不要关键字inner,此为系统默认)

select*

from[Book]asbinnerjoin[Student]ass

ONb.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]asbleftjoin[Student]ass

ONb.StudentId=s.StudentId

 

oracle的写法

select*

fromBook  b ,Student s

whereb.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]asbrightjoin[Student]ass

ONb.StudentId=s.StudentId

 

oracle的写法

select*

fromBook  b ,Student s

whereb.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


TAG:

 

评分:0

我来说两句

Open Toolbar