一个存储过程部分内容如下:
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没有被回滚,什么原因?
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没有被回滚,什么原因?
指定当 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 @sql = 'insert into......'
exec(@sql)
if @@error<>0
begin
rollback tran ss
return 0
end
else
begin
commit tran ss
return 1
endupdate .....
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
要么就全都手动判断回滚