什么是事务
事务就是被绑定在一起作为一个逻辑工作单元的SQL语句组,如果任何一个语句操作失败那么整个操作就被失败,进而回滚到操作前状态,或者是上个节点
什么时候使用
为了确保要么执行,要么不执行,就可以使用事务。
sql server事务的使用是为了确保数据的一致性。
实例展示
下面实例采用存储过程来展示转账事务
数据库展示
go
create proc cp_charge --创建存储过程
(
@idOut int, --转出账户
@idIn int, --转入账户
@remain decimal(18,2) --转账金额
)
as
begin Transaction tran_Charge --开始事务
declare @err_nums int
set @err_nums=0
begin try --异常处理
update Customer set Remain=Remain-@remain where ID=@idOut
set @err_nums=@err_nums+@@ERROR
update Customer set Remain=Remain+@remain where ID=@idIn
set @err_nums=@err_nums+@@ERROR
end try
begin catch
print'错误编号:'+convert(varchar,error_number())+'错误消息'+error_message()
set @err_nums=@err_nums+1
end catch
if(@err_nums>0)--说明语句有错
rollback Transaction tran_Change --回滚事务
else
commit Transaction tran_Change --提交事务
调用存储过程
exec cp_charge 转出账户,转入账户,转账金额
exec cp_charge 1,2,300
查看结果
select * from Customer