事务的概念
事务就是被绑定在一起作为一个逻辑工作单元的SQL语句组,如果任何一个语句操作失败那么整个操作就被失败,进而回滚到操作前状态,或者是上个节点。为了确保要么执行,要么不执行,就可以使用事务。要将一组语句作为事务考虑,就需要通过ACID测试,即原子性,一致性,隔离性和持久性。
事务的ACID特性:
1) 原子性(Atomicity)
2)一致性(Consistency)
3) 隔离性(Isolation)
4)持续性(Durability )
T-SQL使用下列语句来管理事务:
开始事务:BEGIN TRANSACTION
提交事务:COMMIT TRANSACTION
回滚(撤销)事务:ROLLBACK TRANSACTION
存储点语句:SAVE TRANSACTION
举例
用户a转账给用户b
a用户账户减
b用户账户加
–定义一个变量,记录错误数
declare @error_nums int
set @error_nums=0
–开始事务
begin transaction tran_change
begin try
update Customer set remain=(remain+@Remain) where id=@idOut
set @error_nums=@error_nums+@@error
update Customer set remain=(remain-@Remain) where id=@idIn
end try
begin catch
set @error_nums=@error_nums+1
print '错误异常:'+convert(varchar,error_number())+'错误信息'+error_message()
end catch
if(@error_nums>0)--表示前面有错
rollback transaction tran_change --回滚事务
else
commit transaction tran_change --提交事务