SET XACT_ABORT ON
BEGIN TRANIF @@ERROR<>0 
ROLLBACK TRAN
else
COMMIT TRAN

解决方案 »

  1.   

    --这样就可以了.
    SET XACT_ABORT ON
    BEGIN TRAN
    ...处理语句
    COMMIT TRAN
      

  2.   

    SET XACT_ABORT ON  --设置了它,出错时事务自动回滚,不需要写回滚代码
      

  3.   

    SET XACT_ABORT
    指定当 Transact-SQL 语句产生运行时错误时,Microsoft&reg; SQL Server&#8482; 是否自动回滚当前事务。语法
    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 的设置是在执行或运行时设置,而不是在分析时设置。