韩银虎 2021-05-20 10:03 采纳率: 60%
浏览 28
已采纳

mysql存储过程及流程控制

创建一个用户存取钱的存储过程(pro_upuser):
a.要求含有两个参数,用于传递用户id和用户存取金额。
b.当金额为正数时代表存钱,用户账户金额要增加; 
  为负数时表示取钱,要先判断余额是否充足,如果充足就可以取钱,并修改用户余额,否则提示金额不足

 

请问如何实现这个存储过程,求大神指点

  • 写回答

1条回答 默认 最新

  • benbenli 2021-05-20 11:20
    关注
    CREATE PROCEDURE pro_upuser(IN id INT, IN amount DECIMAL(10.2))
    BEGIN
        IF amount > 0 THEN
            UPDATE  Account
            SET     Balance = Balance + amount 
            WHERE   account_id = id;
        ELSE
            DECLARE Bal DECIMAL(10,2)
            SELECT Balance INTO BalFROM Account WHERE account_id = id;
    
            IF BAL + amount > 0 THEN
                UPDATE  Account
                SET     Balance = Balance + amount 
                WHERE   account_id = id;
            ELSE
                SET MESSAGE_TEXT = 'Insufficient balance.'
            END IF
        END IF
    END
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 ansys fluent计算闪退
  • ¥15 有关wireshark抓包的问题
  • ¥15 Ubuntu20.04无法连接GitHub
  • ¥15 需要写计算过程,不要写代码,求解答,数据都在图上
  • ¥15 向数据表用newid方式插入GUID问题
  • ¥15 multisim电路设计
  • ¥20 用keil,写代码解决两个问题,用库函数
  • ¥50 ID中开关量采样信号通道、以及程序流程的设计
  • ¥15 U-Mamba/nnunetv2固定随机数种子
  • ¥30 C++行情软件的tick数据如何高效的合成K线