使用存储过程实现存款或取款业务

迷失的小小小鸟 2014-04-16 09:33:03

if exists(select name from sysobjects where name='usp_takeMoney')
drop proc usp_takeMoney
go
create proc usp_takeMoney
@name varchar(20),--存款用户姓名
@type char(4),--交易类型
@money int,--金钱
@pass char(6)=null--密码
as
declare @cardID CHAR(19)--用户1卡号
declare @error int
declare @balance int
set @error=0
--获取卡号
select @cardID=cardID from cardInfo where customerID=
(select customerID from userInfo where customerName=@name)

--存款,如果类型是存入,就执行下列事务
if @type='存入'
begin
--开启事务
begin transaction
insert tradeInfo values(DEFAULT,@type,@cardID,@money,null)
set @error=@error+@@error
update cardInfo set balance=balance+@money where cardID=@cardID
set @error=@error+@@error
print '交易正进行,请稍后……'
if @error=0
begin
print '交易成功!交易金额:'+convert(varchar(20),@money)
select @balance=balance from cardInfo
print '卡号'+@cardID+' 余额:'+convert(varchar(20),@balance)
commit transaction
end
else
begin
print '交易失败!'
rollback transaction
end
end

--取款,否则执行支取
else if(@type = '支取')
begin
begin transaction
insert tradeInfo values(DEFAULT,@type,@cardID,@money,null)
set @error=@error+@@error
update cardInfo set balance=balance-@money where cardID=@cardID and pass=@pass and @money<balance
set @error=@error+@@error
print '交易正进行,请稍后……'
if @error=0
begin
print '交易成功!交易金额:'+convert(varchar(20),@money)
select @balance=balance from cardInfo
print '卡号'+@cardID+' 余额:'+convert(varchar(20),@balance)
commit transaction
end

else
begin
if(@pass<>(select pass from cardInfo))
raiserror('密码错误',16,1)
if(@balance>(select balance from cardInfo))
raiserror('交易失败!余额不足',16,1)
rollback transaction
end
end

exec usp_takeMoney @name ='张三',@type='支取',@money=3000,@pass='888888'

ps:我存款的事务执行是可以的,但是取款的时候明明我故意把密码写错或者取款金额大于余额,程序仍然执行成功,就是上面的图片,不知道哪步出错了,没进事务去,求各位大大解惑,本人新人
...全文
625 6 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
hexiaojie 2014-04-17
  • 打赏
  • 举报
回复
if 逻辑判断不严谨,哪有最后判断密码的啊,把密码判断优先提前
  • 打赏
  • 举报
回复
银行的取款业务不会这么简单的
發糞塗牆 2014-04-17
  • 打赏
  • 举报
回复
update cardInfo set balance=balance-@money where cardID=@cardID and pass=@pass and @money<balance 你支取的这一步,就算密码错误,它也不会报错啊,只是返回null而已。所以@@error捕获不到
發糞塗牆 2014-04-17
  • 打赏
  • 举报
回复
可以把@@error那个判断前面先对select结果集是否为空的判断,如果为空,就返回错误,@@error不是业务级别的判断
卖水果的net 版主 2014-04-17
  • 打赏
  • 举报
回复
代码我没有看完,提个建议,如果你把你代码格式化一下,或者用 CSDN 提供格式,大家一看就明白,这个要多花好几分钟的时间。
select * from ttt
  • 打赏
  • 举报
回复
正如1楼所说,执行成功,不代表你数据库中的数据就已经修改了。 另外逻辑有错误: 首先应该判断密码是否正确,然后才能进行业务

34,837

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧