当前位置: 代码迷 >> Sql Server >> 存储过程中急需远程访问其他数据库
  详细解决方案

存储过程中急需远程访问其他数据库

热度:42   发布时间:2016-04-24 09:32:16.0
存储过程中需要远程访问其他数据库
在存储过程中需要使用两个参数,目的是从远程服务器把数据拷贝到本地数据库,
因此还调用了 “sp_addlinkedserver” 和 “sp_addlinkedsrvlogin” 这两个过程:


create proc proc_abcd (@date_from datetime,@date_to datetime )
as 

if not exists(select 1 from sys.servers where name='RemoteServerName')
begin
exec sp_addlinkedserver 'RemoteServerName','', 'SQLOLEDB', '192.168.1.8' 
exec sp_addlinkedsrvlogin   'RemoteServerName', 'false ',null, 'MyUserName', 'MyPassword' 
end 

insert into tableB 
select * from [RemoteServerName].[DateBase1].[dbo].tableA as tba 
where tba.[date] between @date_from and @date_to


exec proc_abcd @date1, @date2


运行的时候出现问题,提示没有创建远程连接,需要调用 “sp_addlinkedserver” 过程创建,我在proc_abcd里面通过if条件语句创建了但为什么还提示没有呢?
如果我加一个“go”
if...
begin...
end...
go

结果又截断了变量的作用域,提示需要定义变量。

请问应该怎么解决?谢谢高手解释。
------解决思路----------------------
create proc proc_abcd (@date_from datetime,@date_to datetime )
as 
  
if not exists(select 1 from sys.servers where name='RemoteServerName')
begin
exec sp_addlinkedserver 'RemoteServerName','', 'SQLOLEDB', '192.168.1.8' 
exec sp_addlinkedsrvlogin   'RemoteServerName', 'false ',null, 'MyUserName', 'MyPassword' 
end 
EXEC('insert into tableB 
select * from [RemoteServerName].[DateBase1].[dbo].tableA as tba 
where tba.[date] between '''+CONVERT(VARCHAR,@date_from)+''' and '''+CONVERT(VARCHAR,@date_to)+'''')
 GO
  相关解决方案