求教各位一个跨服务器操作的存储过程:
我在本地数据库的存储过程里例如写到:INSERT INTO [10.3.3.133].BYDCAR.dbo.print (VIN) VALUES (@AUTO_VIN)
但是由于网络中断连接或者IP为10.3.3.133的这台服务器死机等问题,导致我在执行上面的语句时出现了超时并且把我的机器拖死的
问题.
现在各位大侠能不能帮我在执行上面语句时先判断一下能不能连上10.3.3.133服务器并且连不上报出相应错误而不执行INSERT语句!
谢谢各位!
我在本地数据库的存储过程里例如写到:INSERT INTO [10.3.3.133].BYDCAR.dbo.print (VIN) VALUES (@AUTO_VIN)
但是由于网络中断连接或者IP为10.3.3.133的这台服务器死机等问题,导致我在执行上面的语句时出现了超时并且把我的机器拖死的
问题.
现在各位大侠能不能帮我在执行上面语句时先判断一下能不能连上10.3.3.133服务器并且连不上报出相应错误而不执行INSERT语句!
谢谢各位!
http://topic.csdn.net/u/20080718/11/70403f9d-8012-4d86-90d5-d1a83b68b837.html
EXEC sp_addlinkedserver 'erp','','MSDASQL',NULL,NULL,'DRIVER={SQL Server};SERVER=10.100.0.50;UID=xuh;PWD=xuhua77;'
exec sp_addlinkedsrvlogin @rmtsrvname='erp',@useself='false',@locallogin='sa',@rmtuser='xuh',@rmtpassword='xuhua77'
调用
select top 100* from erp.datatemp.xuh.mainProductcode
select top 1* from erp.erppossystem.dbo.tblProductCode
http://topic.csdn.net/u/20080612/22/bb2dfa83-1cf3-4a0b-9bd4-5a39e6193556.html
begin try
begin tran
declare @AUTO_VIN int
set @AUTO_VIN=5
INSERT INTO [10.3.3.133].BYDCAR.dbo.print (VIN) VALUES (@AUTO_VIN)
commit tran
end try
begin catch
rollback
end catch用事务看看,估计不会拖死吧,超时了应该会抱错误哦
http://topic.csdn.net/u/20080612/22/bb2dfa83-1cf3-4a0b-9bd4-5a39e6193556.html
--如果经常访问或数据量大,建议用链接服务器--创建链接服务器
exec sp_addlinkedserver 'server_lnk','','SQLOLEDB','远程服务器名或ip地址'
exec sp_addlinkedsrvlogin ' server _lnk','false',null,'用户名','密码'
exec sp_serveroption ' server _lnk','rpc out','true' --这个允许调用链接服务器上的存储过程
go--查询示例
select * from srv_lnk.数据库名.dbo.表名--导入示例
select * into 表 from srv_lnk.数据库名.dbo.表名go
--以后不再使用时删除链接服务器
exec sp_dropserver 'srv_lnk','droplogins'--如果只是临时访问,可以直接用openrowset
--查询示例
select * from openrowset('SQLOLEDB'
,'sql服务器名';'用户名';'密码'
,数据库名.dbo.表名)--导入示例
select * into 表 from openrowset('SQLOLEDB'
,'sql服务器名';'用户名';'密码'
,数据库名.dbo.表名)