一个存储过程部分内容如下:
begin tran
....
set   @sql   = 'insert into......'
exec(@sql)
update .....if @@error<>0
 begin
  rollback tran ss
  return 0
 end
else
 begin
 commit tran ss
 return 1
 end....当insert发生生了错误时,结果是执行了update的结果,update没有被回滚,什么原因?

解决方案 »

  1.   

    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。唯一不需要该选项的情况是提供程序支持嵌套事务时。
      

  2.   

    begin tran
    ....
    set   @sql   = 'insert into......'
    exec(@sql)
    if @@error<>0
     begin
      rollback tran ss
      return 0
     end
    else
     begin
     commit tran ss
     return 1
     endupdate .....
      

  3.   

    SET XACT_ABORT ON
    begin tran
    ....
    set   @sql   = 'insert into......'
    exec(@sql)
    update .....-----or:begin tran
    ....
    set   @sql   = 'insert into......'
    exec(@sql)
    if @@error<>0
     begin
       Goto ErrLabel
     end
    update .....
    if @@err<>0
     begin
       Goto ErrLabel
     end
    else
     begin
     commit tran ss
     return 1
     endErrLabel:
     begin
      rollback tran ss
      return 0
     end
      

  4.   

    同意楼上大侠,要么用SET XACT_ABORT ON
    要么就全都手动判断回滚
      

  5.   

    begin……end中间等于又起了一个新的事务,你回滚的只是begin……end中间的东西