首页 > 代码库 > sql 查询 – left join on
sql 查询 – left join on
<style type="text/css">
p{line-height: 200%}</style>
1. 问题引入
主要是为了查询在一个表中出现,而不在另一个表中出现的数据,具体来说:
如下图所示, 有A、B两个表,其中B表的Aid字段参照A表的主键id,为了查询在A表中出现,却没有被B表引用的数据;
限定条件:A和B中is_deleted字段为‘n’ 并且B中type为‘common’。
2. 解决方法
2.1 left join on
使用not in可以方便实现,具体为:
selectp.id, p.is_deleted, q.id fromA as p left join B as q onq.is_deleted = ‘n‘ and q.type = ‘common‘ wherep.is_deleted = ‘n‘ and q.id is null
其中on主要是对B表进行限定,不会对A表进行限定,即使将p.is_deleted = ‘n‘ 写在on之后也没有作用;
where是对形成的虚拟表进行再次限定,可以将对A表的查询条件设定在这里,具体结果如下:
2.2 其他方法
当然还可以使用其他方法,比如not in 等,可以参考:
(数据库篇) SQL查询~ 存在一个表而不在另一个表中的数据
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。