如果系统是server 2003,参看Error message: OLE DB provider SQLOLEDB was unable to begin a distributed transaction http://support.microsoft.com/default.aspx?scid=kb;en-us;816701
你的上下文中有启动分布式事务,而这个远程登录的设置可能不支持分布式事务。如果你前面有Begin Transaction或者Begin DISTRIBUTED Transaction都会试图分布式事务。可以这样测试你的这个链接服务器是否支持分布式事务: begin trans insert into srv_lnk.myDatebase.dbo.updateNum (SiteID,updateNum) values (1,1) commit trans如果不支持的话,最好把你存储过程中的逻辑改为不需要分布式事务的。
1.启动分布式事务MS DTC 2.在过程或者触发器设置SET XACT_ABORT OFF
不好意思,有点弄错了 我在我的电脑测试了一下: 1.启动分布式事务MS DTC --这个保留,我的本来就是启动的 2.在过程或者触发器设置SET XACT_ABORT OFF --这个要更正SET XACT_ABORT ON 我原本也有这样的问题,加了SET XACT_ABORT ON 就ok!SET XACT_ABORT ON insert into srv_lnk.myDatebase.dbo.updateNum (SiteID,updateNum) values (1,1) SET XACT_ABORT OFF
SET XACT_ABORT 指定当 Transact-SQL 语句产生运行时错误时,Microsoft® SQL Server™ 是否自动回滚当前事务。 语法 SET XACT_ABORT { ON | OFF } 注释 当 SET XACT_ABORT 为 ON 时,如果 Transact-SQL 语句产生运行时错误,整个事务将终止并回滚。为 OFF 时,只回滚产生错误的 Transact-SQL 语句,而事务将继续进行处理。编译错误(如语法错误)不受 SET XACT_ABORT 的影响。对于大多数 OLE DB 提供程序(包括 SQL Server),隐性或显式事务中的数据修改语句必须将 XACT_ABORT 设置为 ON。唯一不需要该选项的情况是提供程序支持嵌套事务时。有关更多信息,请参见分布式查询和分布式事务。 SET XACT_ABORT 的设置是在执行或运行时设置,而不是在分析时设置。
begin trans
insert into srv_lnk.myDatebase.dbo.updateNum (SiteID,updateNum) values (1,1)
commit trans如果不支持的话,最好把你存储过程中的逻辑改为不需要分布式事务的。
2.在过程或者触发器设置SET XACT_ABORT OFF
我在我的电脑测试了一下:
1.启动分布式事务MS DTC
--这个保留,我的本来就是启动的
2.在过程或者触发器设置SET XACT_ABORT OFF
--这个要更正SET XACT_ABORT ON
我原本也有这样的问题,加了SET XACT_ABORT ON 就ok!SET XACT_ABORT ON
insert into srv_lnk.myDatebase.dbo.updateNum (SiteID,updateNum) values (1,1)
SET XACT_ABORT OFF
SET XACT_ABORT
指定当 Transact-SQL 语句产生运行时错误时,Microsoft® SQL Server™ 是否自动回滚当前事务。
语法
SET XACT_ABORT { ON | OFF }
注释
当 SET XACT_ABORT 为 ON 时,如果 Transact-SQL 语句产生运行时错误,整个事务将终止并回滚。为 OFF 时,只回滚产生错误的 Transact-SQL 语句,而事务将继续进行处理。编译错误(如语法错误)不受 SET XACT_ABORT 的影响。对于大多数 OLE DB 提供程序(包括 SQL Server),隐性或显式事务中的数据修改语句必须将 XACT_ABORT 设置为 ON。唯一不需要该选项的情况是提供程序支持嵌套事务时。有关更多信息,请参见分布式查询和分布式事务。 SET XACT_ABORT 的设置是在执行或运行时设置,而不是在分析时设置。