关于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 b.StatusCode=8
  WHERE  o.ProductId='660016'
就是说,有where条件控制,on后面可以用多个 条件, 查询结果就和第一张截图内容一样了


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

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

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

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

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

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

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

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值