SQL SERVER跨服务器查询(SQL SERVER DBLINK)
首先要开启一个选项
启用Ad Hoc Distributed Queries:
exec sp_configure 'show advanced options',1 reconfigure exec sp_configure 'Ad Hoc Distributed Queries',1 reconfigure exec sp_configure 'Ad Hoc Distributed Queries',0 reconfigure exec sp_configure 'show advanced options',0 reconfigure --跨服务器查询如下:
SELECT a.*,b.stor_Name from OPENROWSET('MSDASQL', ORDER BY a.au_lname, a.au_fname --其中,tom为远程服务器名,stores 是本机数据库pubs中的表 --需要注意的是若二个表中的记录数目不同会导致某一个表产生完全重复的行, --得到的记录集的行数为最长的那个表中的行数 如: insert into dbo.Kqmx_200704 select * from openrowset('MSDASQL', 另: 连接远程服务器进行数据查询时可以这么做:select * from [**.**.**.**].test.dbo.t1 不过,不出意外的话会报错:在 sysservers 中未能找到服务器 '**.*.**.**'。请执行 sp_addlinkedserver 以将服务器添加到 sysservers。 添加sysservers:exec 再查询:select * from srv_lnk.test.dbo.t1 (因为定义了“别名”,所以这儿“别名”) 除非两个服务器上的该用户的密码一样,否则会报:用户 '**' 登录失败。 指定登录用户:exec 再查询:select * from srv_lnk.test.dbo.t1,如果无意外的话就应该是成功的 sp_addlinkedserver 创建一个链接的服务器,使其允许对分布式的、针对 OLE DB 数据源的异类查询进行访问。在使用 sp_addlinkedserver 创建链接的服务器之后,此服务器就可以执行分布式查询。如果链接服务器定义为 Microsoft? SQL Server?,则可执行远程存储过程。 Exec sp_droplinkedsrvlogin server,Null Exec sp_dropserver server EXEC sp_addlinkedserver @server= 'server ',--被访问的服务器别名 @srvproduct= ' ', @provider= 'SQLOLEDB ', @datasrc= '10.23.11.28,3342 ' --要访问的服务器 EXEC sp_addlinkedsrvlogin 'server ', --被访问的服务器别名 'false ', NULL, 'la0001 ', --账号 'aaaaaa ' --密码 链接服务器没问题,在查询分析器里执行例如:select * from [192.168.0.119].fash.dbo.vwAllUser没问题. 但如果想建立一个简单的存储过程 ...... |
|