sql如何删除某两张表中不相同的的数据,以某一字段为比较

两张表中都有一个字段的内容是对应的,只有有一个表中的数据多点,想把多的都删掉... 两张表中都有一个字段的内容是对应的,只有有一个表中的数据多点,想把多的都删掉 展开
 我来答
mzcheng1
2011-05-20 · TA获得超过300个赞
知道小有建树答主
回答量:421
采纳率:0%
帮助的人:222万
展开全部
这样,比如:
少数据的表为:A
多数据的表为:B
你需要的字段:C
select C from A,说明这个是A表里面的C字段
然后B中,你不要超出C的,那么你可以这样
select * from B where C in (select C from A)
柴沛文00K
2011-05-20 · TA获得超过635个赞
知道小有建树答主
回答量:1203
采纳率:0%
帮助的人:192万
展开全部
declare @a table(id int)

insert into @a
select 1
union select 2
union select 3
union select 4

declare @b table(id int)

insert into @b
select 1
union select 2
union select 6
union select 5

select * from @a a inner join @b b on a.id=b.id

delete from @a where id not in (select id from @b)

delete from @b where id not in (select id from @a)

select * from @a
select * from @b
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
零临窗听雨
2011-05-22 · 超过26用户采纳过TA的回答
知道答主
回答量:78
采纳率:0%
帮助的人:66.8万
展开全部
这不是都回答了吗,咋看不懂啊。。。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
tcds30
推荐于2018-04-14 · TA获得超过131个赞
知道小有建树答主
回答量:218
采纳率:0%
帮助的人:118万
展开全部
依楼上的事例:
DELETE FROM 表B WHERE C not in (SELECT C FROM A)
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式