如何在触发器中向远程数据库写值?

wweight 2004-06-07 03:33:47
我在本地数据库建一触发器,如何向远程数据库写值?
我用如下代码不行:insert opendatasource('SQLOLEDB','Data Source=211.162.2.100; User ID=test; Password=test').UserInfo.dbo.Job select * from inserted 提示新事务不能登记到指定事务处理器,OLEDB提供程序SQLOLEDB无法启动分布式事务.请高手帮忙,谢谢!!!


...全文
147 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
wweight 2004-06-09
  • 打赏
  • 举报
回复
创建链接服务器在查询分析器中是可以的,但在触发器中就不行了。而且我在局域网内的两台SQL之间是可以的,就是不能向外网写值班,总是提示OLEDB提供程序SQLOLEDB无法启动分布式事务,我研究这个问题有二天了,试了N种方法还是没有搞定,痛苦!!!
Communism 2004-06-09
  • 打赏
  • 举报
回复
--创建链接服务器
exec sp_addlinkedserver 'srv_lnk','','SQLOLEDB','远程服务器名或ip地址'
exec sp_addlinkedsrvlogin 'srv_lnk','false',null,'用户名','密码'
exec sp_serveroption 'srv_lnk','rpc out','true' --这个允许调用链接服务器上的存储过程
go

--查询示例
select * from srv_lnk.数据库名.dbo.表名

--导入示例
select * into 表 from srv_lnk.数据库名.dbo.表名

go
--处理完成后删除链接服务器
exec sp_dropserver 'srv_lnk','droplogins'
wweight 2004-06-09
  • 打赏
  • 举报
回复
高手帮帮忙 http://community.csdn.net/Expert/topic/3073/3073266.xml?temp=.9211847
wweight 2004-06-08
  • 打赏
  • 举报
回复
我在查询分析器里可以实现,但在触发器或存储过程中就不行。请给一个详细例子!
skyboy0720 2004-06-07
  • 打赏
  • 举报
回复
先联接远程服务器,然后就可以向在本地数据库一样,操作里面的数据了!
参考sp_addlinkedserver
wweight 2004-06-07
  • 打赏
  • 举报
回复
???

34,590

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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