存储过程

  • SQL学习系列文章(一)
  • 存储过程

-------------------创建存储过程实现转账-------------------
create proc usp_transfer
@from char(4),
@to char(4),
@balance money,--转账金额
@reusltNumber int output--转账是否成功(1-成功,2-失败,3-余额不足)
as
begin
    --1.判断金额是否足够转账
    declare @money money
    select @money=balance from bank where cid=@from
    if @money-@balance>=10
    begin
        --开始转账
        begin transaction
            declare @sum int=0
            --2.账户1扣钱
            update bank set balance=balance-@balance where cid=@from
            set @sum=@sum+@@error
            --3.账户2加钱
            update bank set balance=balance+@balance where cid=@to
            set @sum=@sum+@@error
            --4.判断执行是否成功,进行提交或者回滚
            if @sum <>0
            begin
                set @reusltNumber=2--转账失败
                rollback
            end
            else
            begin
                set @reusltNumber=1--转账成功
                commit
            end
    end
    else
    begin
        set @reusltNumber=3--余额不足
    end
end

declare @r int
exec usp_transfer @from='0001',@to='0002',@balance=500,@reusltNumber=@r output
print @r


--执行
declare @r int
exec usp_transfer @from='0001',@to='0002',@balance=50,@resultnumber=@r output
print @r

--然后查询结果
--select * from bank

数据库表内容
表名:bank
cid char(4)
balance money
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值