利用约束,事务,存储过程 模拟银行转账

准备工作

1.创建表
create Table T_User(
id int identity(1,1) primary key,
[Name] nvarchar(50),
[Money]  int
)
2.添加数据
insert into T_User 
select N'张三',1000 union
select N'李四',1000

添加约束

---添加约束
alter table T_User
add constraint CK_Money check([Money]>=0)

创建存储过程

go
--创建存储过程
create proc cp_aaa  --(cp_aaa存储过程名称可以自取)
(
  @idOut int,--定义转出的账号ID
  @idIn int,--定义转入的账号ID
  @remain  int--定义转账金额
)
as
--开始事务
begin Transaction tran_Charge
--定义变量记录错误数
declare @err_nums int
set @err_nums=0
begin try
update T_User set Money=Money-@remain where ID=@idOut
set @err_nums=@err_nums+@@error
update T_User set Money=Money+@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_Charge--回滚事务
else 
commit Transaction tran_Charge--提交事务

调用

exec cp_aaa 2,1,500  --(2表示转出的账号ID,1表示转入的账号ID,500表示金额)

注释

1.
begin Transaction  tran_Charge    --开始事务
rollback Transaction tran_Charge  --回滚事务
commit Transaction tran_Charge    --提交事务
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值