sql 查询 – left join on

时间:2014-05-16 08:38:24   收藏:0   阅读:334
  1. 问题引入

 

主要是为了查询在一个表中出现,而不在另一个表中出现的数据,具体来说:

如下图所示, 有A、B两个表,其中B表的Aid字段参照A表的主键id,为了查询在A表中出现,却没有被B表引用的数据;

限定条件:A和B中is_deleted字段为‘n’  并且B中type为‘common’。

bubuko.com,布布扣

  2. 解决方法

 

2.1 left join on

使用not in可以方便实现,具体为:

bubuko.com,布布扣
select 
    p.id, p.is_deleted, q.id
from 
    A as p left join B as q
on 
    q.is_deleted = n and q.type = common
where 
    p.is_deleted = n and q.id is null
bubuko.com,布布扣

 

其中on主要是对B表进行限定,不会对A表进行限定,即使将p.is_deleted = n写在on之后也没有作用;

where是对形成的虚拟表进行再次限定,可以将对A表的查询条件设定在这里,具体结果如下:

bubuko.com,布布扣

 

2.2 其他方法

当然还可以使用其他方法,比如not in 等,可以参考:

(数据库篇) SQL查询~ 存在一个表而不在另一个表中的数据

sql 查询 – left join on,布布扣,bubuko.com

评论(0
© 2014 mamicode.com 版权所有 京ICP备13008772号-2  联系我们:gaon5@hotmail.com
迷上了代码!