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

迷失的小小小鸟 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:我存款的事务执行是可以的,但是取款的时候明明我故意把密码写错或者取款金额大于余额,程序仍然执行成功,就是上面的图片,不知道哪步出错了,没进事务去,求各位大大解惑,本人新人
...全文
600 6 打赏 收藏 转发到动态 举报
写回复
用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楼所说,执行成功,不代表你数据库中的数据就已经修改了。 另外逻辑有错误: 首先应该判断密码是否正确,然后才能进行业务
要求编写程序模拟银行账户的存、取款操作。按要求完成以下步骤: 步骤1:编写程序Account.java,其中定义银行账户类Account。该类中有账号、姓名、 存款余额等数据域,余额默认是0;有存款取款、获取当前余额等方法。其中账号为长度 为12位数字的字符串,姓名为字符串,存款余额为double。 步骤2:编写名为CreditAccount类的信用卡账户类。该类继承自Account类,增加一 个透支限额(double)数据域,透支限额默认为1000。同时该类账户取款时允许透支,但不 能超过透支限额。 步骤3:编写名为SavingAccount的储蓄账户类SavingAccount。该类继承自Account 类。该类账户取款时不允许透支。 步骤4:编写名为Bank的模拟银行类,其中可以存储多个类型可能是信用卡账户或储 蓄账户的对象(可以用数组或ArrayList实现)。该类包含以下方法: 开户:即增加一个新的账户,注意:不允许两个账户的账号相同 销户:即删除一个已有的账户 查询账户:根据一个账号,查询有无该账号的账户 统计目前银行的存款总余额的方法。 统计目前银行的信用卡账户总透支金额的方法。 统计目前总账户数。 统计目前信用卡账户数 统计目前储蓄卡账户数 步骤5:编写客户端类Client.java完成以下功能: 编写一个静态方法,创建一个银行对象,并随机生成10个账号从1000 0000 0000 0000到1000 0000 0000 0009,类型不同的账户。 main方法中模拟几次开户操作。 main方法中模拟几次销户操作。 模拟几个对指定账号的存款取款操作。 输出银行的总账户数、总余额、总透支数、各类具体账户数。

34,576

社区成员

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

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