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

怎么同时从两个数据库里读取数据?
注意:数据库分别放在不同的服务器上

------解决方案--------------------
作好链接服务器,select * from server1.db.dbo.table;select * from server2.db.dbo.table;
------解决方案--------------------
通过建立链接服务器
--创建链接服务器
exec sp_addlinkedserver 'srv_lnk','','SQLOLEDB','远程服务器名或ip地址'
exec sp_addlinkedsrvlogin 'srv_lnk','false',null,'用户名','密码'

select * from srv_lnk1.数据库名.dbo.表名
select * from srv_lnk2.数据库名.dbo.表名


------解决方案--------------------
SQL code

--创建链接服务器
exec sp_addlinkedserver   'srv_lnk ', ' ', 'SQLOLEDB ', 'TRAINING-001' 
exec sp_addlinkedsrvlogin  'srv_lnk ', 'false',null, 'sa ', 'sa ' 
go 
--查询示例
select * from srv_lnk.aa.dbo.t 
--导入示例
select * into 表from srv_lnk.数据库名.dbo.表名
--以后不再使用时删除链接服务器
exec sp_dropserver  'srv_lnk ', 'droplogins ' 
go 
--如果只是临时访问,可以直接用openrowset 
--查询示例
select * from openrowset( 'SQLOLEDB ' 
, 'ElvisGao '; 'sa '; 'sa ' 
,aa.dbo.test) 

--导入示例
select * into 表from openrowset( 'SQLOLEDB ' 
, 'sql服务器名'; '用户名'; '密码' 
,数据库名.dbo.表名)