该操作未能执行,因为 OLE DB 提供程序 'SQLOLEDB' 无法启动分布式事务。
现在在两个服务器间操作数据,已经建立了连接,写了几个存储过程,单独执行都是没有问题的,但是如果放大一个事物中统一执行就会有这样的问题:该操作未能执行,因为 OLE DB 提供程序 'SQLOLEDB' 无法启动分布式事务。
按网上说的方法解决怎么还是不对,到底该怎么办?
网上是这么说的:
1、运行 regedt32,浏览至 HKEY_LOCAL_MACHINE\Software\Microsoft\MSDTC。
添加一个 DWORD 值 TurnOffRpcSecurity,值数据为 1。
2、重启MS DTC服务。
3、打开“管理工具”的“组件服务”。
a. 浏览至"启动管理工具"。
b. 选择"组件服务"。
c. 展开"组件服务"树,然后展开"我的电脑"。
d. 右键单击"我的电脑",然后选择"属性"。
在 MSDTC 选项卡中,确保选中了下列选项:
网络 DTC 访问
网络管理
网络事务
XA 事务
另外,"DTC 登录帐户"一定要设置为"NT Authority\NetworkService"。
4、重启MS DTC服务。
5、再次运行 regedt32,浏览至 HKEY_LOCAL_MACHINE\Software\Microsoft\MSDTC,然后删除 TurnOffRpcSecurity 项。
郁闷。。。。。。