SQL server事务

事务要求语句全部执行成功或者全部不执行。作为一个整体进行操作。

因此适用于一些特殊场景

事务分为显式事务和隐式事务

隐式事务:不用刻意强调,本身就是事务的语句,如单独的sql语句;

语法: 

--创建事务:
       begin transaction
       begin
      sql语句1

      sql语句2

      sql语句3

        ...
       if(@@ERROR<>0)    --判断语句是否出现错误
              begin
                  rollback --出现错误则各个表回滚到自己的原始状态
               end
       else
               begin
                  commit transaction --未出现错误则提交保存
               end
       end

--------------------------------------------------------------------例:
begin transaction   --事务开始
commit transaction  --事务提交
rollback transaction--事务回滚

--事务:事务中的语句如果要执行都执行,如果有一个不执行所有语句都不执行
--一个操作里面有10条语句


--业务场景:A银行  B银行
--用户admin在两个行中分别开设了两个账号,admin从A银行进行金额转账 转到B银行
alter proc pr_zhuanzhang
@a_account varchar(50),
@zmoney int
as
   declare @ymoney int
   select @ymoney=money from abank where Account=@a_account--查出余额
   if(@zmoney>@ymoney)
           begin
               print '余额不足'
           end
   else
   begin
       --创建事务
       begin transaction
       begin
       --先从a银行减掉
       update abank set money=money-@zmoney where Account=@a_account
       --把减掉的钱加到B银行
       update bbank set money=money+@zmoney where Account=@a_account
       if(@@ERROR<>0)
       begin
          rollback --各个表回到自己的原始状态
       end
       else
       begin
          commit transaction --提交
       end
       end
   end
 go

  
 exec pr_zhuanzhang 'admin',500
 
 select * from abank  
 
 
 select * from bbank
 
 SET IMPLICIT_TRANSACTIONS ON 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值