如果系统是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

解决方案 »

  1.   

    系统是server 2003,如果msdtc有问题那么在查询分析器里也不可能成功运行阿~
      

  2.   

    你的上下文中有启动分布式事务,而这个远程登录的设置可能不支持分布式事务。如果你前面有Begin Transaction或者Begin DISTRIBUTED Transaction都会试图分布式事务。可以这样测试你的这个链接服务器是否支持分布式事务:
    begin trans
    insert into srv_lnk.myDatebase.dbo.updateNum (SiteID,updateNum) values (1,1)
    commit trans如果不支持的话,最好把你存储过程中的逻辑改为不需要分布式事务的。
      

  3.   

    1.启动分布式事务MS DTC
    2.在过程或者触发器设置SET XACT_ABORT OFF
      

  4.   

    不好意思,有点弄错了
    我在我的电脑测试了一下:
    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 的设置是在执行或运行时设置,而不是在分析时设置。