【学习笔记】事务+存储过程实现用户转账功能

这篇博客介绍了如何通过Navicat在数据库端实现事务和存储过程,并详细阐述了如何在Java中调用这些存储过程来完成用户转账操作。
摘要由CSDN通过智能技术生成
1.数据库端(Navicat)实现事务和存储过过程的函数。
IN `fromuser` varchar(20),IN `touser` varchar(20),IN `balance` float,OUT `flag` varchar(20)
BEGIN
	#Routine body goes here...
	-- 声明变量t
  DECLARE t FLOAT;
	-- 声明变量result,执行所有sql后受影响的行
	DECLARE result INT;
	set result = 0;
	-- 给t赋值,用于后续判断转账者是否有足够金额
	SELECT balance into t from trans WHERE uname=fromuser;
	-- 判断转账者账户是否有足够金额,若足够,则执行update,账户扣钱
	if(t-amount>=0)then
			-- 开启事务
			start TRANSACTION;
			-- 转入金额
			UPDATE trans SET balance=balance+amount WHERE uname=touser
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值