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

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

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

请问应该怎么解决?谢谢高手解释。
...全文
206 3 打赏 收藏 转发到动态 举报
写回复
用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
你这样试下
qlite数据库远程管理器,只要在SQLITE数据文件所在目录下运行SQLITE3SERVER服务器程序就可以在于之联网的机器管理SQLITE数据库。可同时管理多台SQLITE数据库服务器。 实现的功能如下: 1、可列出远程SQLITE数据库文件 2、可分页查看数据库的记录,简单及人性化的界面实现所见即所得的操作,免去了对数据库的繁琐操作;可对UTF-8格式的记录查看 3、可远程创建表 4、远程删除表 5、远程增加、删除、修改表记录,这些操作与 SQLSERVER2000的操作类似,非常方便 6、可以存储二进制文件到数据库,也可从数据库下载二进制文件 7、WINDOWS下只要在数据库所在目录下运行sqlite3server.exe,然后点击启动按钮即可 8、LINUX下,在新建终端输入./sqlitemain,拷贝libsqlite3.so到/usr/lib目录下 9、启动sqlitemanage.exe,点击工具栏的第二个远程登录按钮输入IP,WINDOWS可以通过点击查询数据库名得到远程SQLITE数据库名选择一个数据库登录,LINUX直接输入远程数据库名,就可以以所见即所得的方式管理远程的不同平台下的SQLITE数据库,而且可以远程运行SQL语句,直接通过点击数据表格对数据库记录进行更新包括增加新记录、删除、修改,可以上传下载二进制文件到数据库,可批量导入TXT文件到数据库,可以查看索引,支持多数据库同时操作。

27,579

社区成员

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

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