关于数据库事务

定义: 事务就是被绑定在一起作为一个逻辑工作单元的SQL语句组,如果任何一个语句操作失败那么整个操作就被失败,进而回滚到操作前状态,或者是上个节点。为了确保要么执行,要么不执行,就可以使用事务。要将一组语句作为事务考虑,就需要通过ACID测试,即原子性,一致性,隔离性和持久性。

实例:

这里仅需用到余额字段Remain
关于数据库事务_第1张图片代码:

–a转给b
–建立存储过程以便运行事务
create proc cp_charge(
–接收转账出去的人的ID
@idOut int,
–接收到账人的ID
@idIn int,
–接收转账金额
@remain decimal(18,2)
)
as
–创建事务语法
begin Transaction tran_Change
–编写传输错误时的代码
declare @err_nums int
set @err_nums=0
begin try
update Customers set Remain=Remain-@remain where ID=@idOut
set @err_nums=@err_nums+@@ERROR
update Customers 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 1,2,100

运行效果:

在这里插入图片描述
结论: 事务即为执行的一个语句组,核心在于,要么全部执行,要么全部不执行

你可能感兴趣的:(关于数据库事务)