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

本文介绍了如何通过SQL查询实现主表与子表之间的高效关联,包括显示所有子表记录、检查主表ID是否存在子表中及相应属性,并通过左连接查询展示关键信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

主表记录:
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



 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值