如何筛选出A表中不在B表里的数据,并且把不在B表里的数据添加到A表中

wushuyao 2010-04-12 05:34:34
A 表
id name
1 1
2 2
3 3



B 表
id name
1 1
2 2
3 3
4 4
5 5


得到结果如下:

A表
id name
1 1
2 2
3 3
4 4
5 5


就还有35分了,全给了出来 大家帮个忙,在此谢谢各位。

...全文
132 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
htl258_Tony 2010-04-12
  • 打赏
  • 举报
回复
insert a
select * from b
except
select * from a
东那个升 2010-04-12
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 ldslove 的回复:]
SQL code
insert a
select * from a
except
select * from b
[/Quote]

insert a
select * from b
except
select * from a
东那个升 2010-04-12
  • 打赏
  • 举报
回复

insert a
select * from b
where not exists(select 1 from a where checksum(b.id,b.name) =checksum(id,name))
东那个升 2010-04-12
  • 打赏
  • 举报
回复
insert a
select * from a
except
select * from b
dawugui 2010-04-12
  • 打赏
  • 举报
回复
--如果只考虑ID
create table A(id int,name int)
insert into a values(1 ,1)
insert into a values(2 ,2)
insert into a values(3 ,3)
create table B(id int,name int)
insert into b values(1 ,1)
insert into b values(2 ,2)
insert into b values(3 ,3)
insert into b values(4 ,4)
insert into b values(5 ,5)
go

insert into a select * from b where id not in (select id from a)

select * from a

drop table a , b

/*
id name
----------- -----------
1 1
2 2
3 3
4 4
5 5

(所影响的行数为 5 行)


*/


--如果同时考虑ID,name.
create table A(id int,name int)
insert into a values(1 ,1)
insert into a values(2 ,2)
insert into a values(3 ,3)
create table B(id int,name int)
insert into b values(1 ,1)
insert into b values(2 ,2)
insert into b values(3 ,3)
insert into b values(4 ,4)
insert into b values(5 ,5)
go

insert into a select * from b where not exists (select 1 from a where a.id = b.id and a.name = b.name)

select * from a

drop table a , b

/*
id name
----------- -----------
1 1
2 2
3 3
4 4
5 5

(所影响的行数为 5 行)


*/
dawugui 2010-04-12
  • 打赏
  • 举报
回复
insert into a select * from b where id not in (select id from a)

22,209

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧