SQL Server 事务及回滚事务的几种方法
第一种:
declare @iErrorCount int
set@iErrorCount=0
begintran Tran1
insertinto t1(Id, c1) values(1,'1')
set@iErrorCount=@iErrorCount+@@error
insertinto t1(Id, c1) values('XX2','2')
set@iErrorCount=@iErrorCount+@@error
if@iErrorCount=0
begin
COMMITTRAN Tran1 --执行事务
end
else
begin
ROLLBACKTRAN Tran1 --回滚事务
end
set@iErrorCount=0
begintran Tran1
insertinto t1(Id, c1) values(1,'1')
set@iErrorCount=@iErrorCount+@@error
insertinto t1(Id, c1) values('XX2','2')
set@iErrorCount=@iErrorCount+@@error
if@iErrorCount=0
begin
COMMITTRAN Tran1 --执行事务
end
else
begin
ROLLBACKTRAN Tran1 --回滚事务
end
第二种:
Begin Try
BeginTran Tran1
insertinto t1(Id, c1) values(1,'1')
insertinto t1(Id, c1) values('XX2','2') --此句产生错误
COMMITTRAN Tran1
END Try
Begin Catch
raiserror 50005N'出错了'
ROLLBACKTRAN Tran1 ---出错后调用回滚
END Catch
BeginTran Tran1
insertinto t1(Id, c1) values(1,'1')
insertinto t1(Id, c1) values('XX2','2') --此句产生错误
COMMITTRAN Tran1
END Try
Begin Catch
raiserror 50005N'出错了'
ROLLBACKTRAN Tran1 ---出错后调用回滚
END Catch
第三种:
SET XACT_ABORT ON----语句产生运行时错误,则整个事务将终止并回滚。
BeginTran
INSERTINTO t1(Id, c1) VALUES(1,'1')
INSERTINTO t1(Id, c1) VALUES('XX2','2') --此句产生错误时,就会回滚整个事务
CommitTran
BeginTran
INSERTINTO t1(Id, c1) VALUES(1,'1')
INSERTINTO t1(Id, c1) VALUES('XX2','2') --此句产生错误时,就会回滚整个事务
CommitTran