关于sql server中的 jion,inner join, left join ,left outer join, right join,right outer join 的几点使用心得

平时我们做关联,一般都是2~3张表,不太关注这样繁杂的写法,那今天咱们就看看这些写法吧

对将要说的这三种,先说一下要介绍的要点:on后面的条件可以放几个?什么时候结合着where条件一起使用?

大家可以先看看这个帖子,帖子的名字是:sqlserver left join的on中如何添加多个查询条件??

链接:http://bbs.csdn.net/topics/270023422

开始咱们的介绍吧

首先对于join 分三块:

1.  join 、join inner (内联)

  我们平时的写法是:

<span style="font-size:14px;">SELECT * FROM A 
JOIN B ON A.ID=B.ID </span>

直接写 join,这样的写法其实就是 inner join ,

on后面就是我们说的条件,后面可以跟多个条件

SELECT TOP 1000 *
  FROM [DB0208].[dbo].[Orders] o
  JOIN [DB0208].[dbo].[BaseOrderStatus] b
  ON o.Status=b.StatusCode AND b.StatusCode=8
  AND o.ProductId='660016'
这种写法是正确的,当然也可以把条件放到where里面

如下写法:

 SELECT TOP 1000 *
  FROM [DB0208].[dbo].[Orders] o
   JOIN [DB0208].[dbo].[BaseOrderStatus] b
  ON o.Status=b.StatusCode 
  WHERE  o.ProductId='660016' AND  b.StatusCode=8

查询结果:

技术分享

2.  left join ,left outer join(左连接)

left join 叫左连接,left outer join叫左外连接,其实是一种,

后面的on,如果没有where条件,on后面只能跟一个关联条件,把之后的条件都加到where里面


left join(左联接): 返回包括左表中的所有记录和右表中联结字段相等的记录

查看如下写法:

SELECT TOP 1000 *
  FROM [DB0208].[dbo].[Orders] o
  LEFT JOIN [DB0208].[dbo].[BaseOrderStatus] b
  ON o.Status=b.StatusCode AND b.StatusCode=8
  AND o.ProductId='660016'

这种写法就是错误,因为第二条件on已经不起作用了,查询结果:

技术分享


正确的写法:

  SELECT TOP 1000 *
  FROM [DB0208].[dbo].[Orders] o
  JOIN [DB0208].[dbo].[BaseOrderStatus] b
  ON o.Status=b.StatusCode 
  WHERE b.StatusCode=8 AND o.ProductId='660016'


当然也可以这么写:

  SELECT TOP 1000 *
  FROM [DB0208].[dbo].[Orders] o
  JOIN [DB0208].[dbo].[BaseOrderStatus] b
  ON o.Status=b.StatusCode AND <span style="font-family: Arial, Helvetica, sans-serif;">b.StatusCode=8 AND</span>
  WHERE  o.ProductId='660016'
就是说,有where条件控制,on后面可以用多个 条件,查询结果就和第一张截图内容一样了


3. right join,right outer join (右连接)

right join 叫右连接,right outer join叫右外连接,其实是一种,

后面的on,也只能跟一个关联条件,和left join是一样的。

right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录

3和2类似,就不再赘述啦。

-------------------------------------

这些是一个小同事问我的,之前一直都想整理,现在就把它写出来,让大家参考,以后有新人再问相关问题,直接给他链接就好了,东西在于精,学习一次,在以后的反复练习中才能掌握。

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。