SQL server事务讲解

什么是事务

事务就是被绑定在一起作为一个逻辑工作单元的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

在这里插入图片描述在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值