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

flyingsheep_mrl 2014-12-10 12:37:29
在存储过程中需要使用两个参数,目的是从远程服务器把数据拷贝到本地数据库,
因此还调用了 “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

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

请问应该怎么解决?谢谢高手解释。
...全文
233 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
flyingsheep_mrl 2014-12-26
  • 打赏
  • 举报
回复
楼上的方法不太合适,但还是受到启发,谢谢!
还在加载中灬 2014-12-10
  • 打赏
  • 举报
回复
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
还在加载中灬 2014-12-10
  • 打赏
  • 举报
回复
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 '''+@date_from+''' and '''+@date_to+'''')
 GO
 
exec proc_abcd @date1, @date2
你这样试下

27,581

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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