MySQL创建随机生成银行卡号的存储过程

 一、

CREATE PROCEDURE Proc_randCardID()

首先创建一个名为Proc_randCardID的存储过程。

二、

DECLARE randSeed INT;

DECLARE randCardId CHAR(16);

声明randSeed和randCardId两个变量,分别用于存储随机种子和生成的银行卡号。

三、

SET randSeed = MONTH(NOW()) * 100000 + SECOND(NOW()) * 1000 + MICROSECOND(NOW()) DIV 1000;

计算随机种子的值。将当前的月份乘以100000,加上当前的秒数乘以1000,再加上当前的毫秒数除以1000(取整数部分),得到一个唯一的随机种子。

四、

SET randCardId = CONCAT('10103576', LPAD(FLOOR(RAND(randSeed) * 100000000), 8, '0'));

使用随机种子生成银行卡后8位数字。首先将固定的前8位数字'10103576'与生成的随机8位数字拼接起来,然后使用LPAD函数在前面补充零,确保银行卡号总长度为16位。

五、

SELECT randCardId AS BankCardNumber;

将生成的银行卡号作为结果返回。

六、

完整代码:

DELIMITER //

CREATE PROCEDURE Proc_randCardID()

BEGIN

    DECLARE randSeed INT;

    DECLARE randCardId CHAR(16);

    -- 产生随机种子 = 当前的月份数 * 100000 + 当前的秒数 * 1000 + 当前的毫秒数

    SET randSeed = MONTH(NOW()) * 100000 + SECOND(NOW()) * 1000 + MICROSECOND(NOW()) DIV 1000;

    -- 使用随机种子生成银行卡后8位数字

    SET randCardId = CONCAT('10103576', LPAD(FLOOR(RAND(randSeed) * 100000000), 8, '0'));

    SELECT randCardId AS BankCardNumber;

END //

DELIMITER ;

七、 

结果: 

 

  • 14
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SmoothSailingT

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值