不同服务器间的SQL语句数据更新!

chd2001 2007-04-04 10:37:07
假如局域网上有两个服务器jimmy-1和jimmy-2
我想将一个库的数据更新到另一个库上
能直接用SQL语句写吗?
比如:
update jimmy-1.库1.dbo.tab1 a
set f1=(select f1 from jimmy-2.库2.dbo.tab2
where a.f2=f2)
...全文
220 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
zhanminga 2007-04-05
  • 打赏
  • 举报
回复
学习一下
chd2001 2007-04-05
  • 打赏
  • 举报
回复
多谢两位!
必须要这样:
update jimmy_1.库1.dbo.tab1
set jimmy_1.库1.dbo.f1=(select f1 from jimmy_2.库2.dbo.tab2
where jimmy_1.库1.dbo.f2=jimmy_2.库2.dbo.tab2.f2)
不能用别名?:
update jimmy_1.库1.dbo.tab1 a
set a.f1=(select f1 from jimmy_2.库2.dbo.tab2 b
where a.f2=b.f2)
OracleRoob 2007-04-04
  • 打赏
  • 举报
回复
--先创建链接服务器,然后再用楼上的SQL语句。


--创建链接服务器
exec sp_addlinkedserver 'srv_lnk','','SQLOLEDB','远程服务器名或ip地址'
exec sp_addlinkedsrvlogin 'srv_lnk','false',null,'用户名','密码'
go

--查询示例
select * from srv_lnk.数据库名.dbo.表名


--以后不再使用时删除链接服务器
exec sp_dropserver 'srv_lnk','droplogins'
go



--如果只是临时访问,可以直接用openrowset
--查询示例
select * from openrowset('SQLOLEDB'
,'sql服务器名';'用户名';'密码'
,数据库名.dbo.表名)


dawugui 2007-04-04
  • 打赏
  • 举报
回复
update tab1
set f1=(select f1 from jimmy_2.库2.dbo.tab2
where f2=jimmy_2.库2.dbo.tab2.f2)

update jimmy_1.库1.dbo.tab1
set jimmy_1.库1.dbo.f1=(select f1 from jimmy_2.库2.dbo.tab2
where jimmy_1.库1.dbo.f2=jimmy_2.库2.dbo.tab2.f2)
dawugui 2007-04-04
  • 打赏
  • 举报
回复
update jimmy_1.库1.dbo.tab1
set f1=(select f1 from jimmy_2.库2.dbo.tab2
where f2=jimmy_2.库2.dbo.tab2.f2)

34,590

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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