SQL查询,主表,在子表中是否有记录的标记

主表记录:
ID Name  
1 AA  
2 BB
3 CC

子表记录:
ID Name Rem
1 AA 100
3 CC 200

=================================

查询字表所有的记录,但是如果在子表中有记录,则显示子表记录,没有则为空。
结果:
ID   Name  Rem
1    AA        100
2    BB
3    CC       200

使用左连接查询:

select 主表.ID,主表.Name,isnull(子表.Rem,'') as Rem
from 主表
left join 子表 on 主表.ID=子表.ID

=================================

想知道主表对应的ID有没有在子表存在的话。

结果:
ID   Name  Rem
1    AA        有
2    BB       无
3    CC      有

SQL code
select 主表.ID,主表.Name,isnull(#Temp.Rem,'无') as Rem
from 主表
left join
(
select distinct ID,'有' as Rem from 子表
) #Temp
on 主表.ID=#Temp.ID
 

或者

select a.ID,a.Name,case when b.Rem is not null then '有' else '无' end as Rem 
from [主表] a left join [子表] b on a.ID = b.ID



 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值