日期:2014-05-18  浏览次数:20576 次

两台服务器间的数据库操作
在两台sql server服务器之间,我要在服务器A中某个表的数据复制到服务器B的数据库表中(它们是两个结构完全相同的数据库),我要在数据库服务器A中用sql语句实现.请问要如何实现呢?

------解决方案--------------------
--创建链接服务器
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.表名)

------解决方案--------------------
select *
from openrowset
('msdasql','driver={sql server};server=远程IP
;uid=用户名;pwd=密码','select * from 数据库名.dbo.tablename') AS a