34,593
社区成员
发帖
与我相关
我的任务
分享
那就从A中delete两个表的交集,然后再把B表不存在于A的记录(包括刚刚删除的)一并insert到A表。
delete A where exsists(select 1 from B where id=A.id)
insert into A select * from B where not exists(select 1 from A where ID=B.ID)
update A set A.name=B.name from A,B where A.id=B.id and A.name!=B.name
insert into A select * from B where not exists(select 1 from A where id=B.id)
--创建链接服务器
exec sp_addlinkedserver 'srv_lnk','','SQLOLEDB','远程服务器名或ip地址'
exec sp_addlinkedsrvlogin 'srv_lnk','false',null,'用户名','密码'
go
--查询示例
select * from srv_lnk.数据库名.dbo.表名
--导入示例
select * into 表 from srv_lnk.数据库名.dbo.表名
--以后不再使用时删除链接服务器
exec sp_dropserver 'srv_lnk','droplogins'
go
--如果只是临时访问,可以直接用openrowset
--查询示例
select * from openrowset('SQLOLEDB'
,'sql服务器名';'用户名';'密码'
,数据库名.dbo.表名)
--导入示例
select * into 表 from openrowset('SQLOLEDB'
,'sql服务器名';'用户名';'密码'
,数据库名.dbo.表名)
update A set A.name=B.name from A,B where A.id=B.id
insert into A select * from B where not exists(select 1 from A where id=B.id)