MySQL生成自增的流水号

生成MySQL流水号

MysSQL生成指定编号

假如我们要生成 类似于 ABCD日期序号 比如
我的购物订单号:SP20211201001并且以后四位自增,类似于这样的场景,该怎么实现呢?

首先我们分析序号,SP为固定字符,20211201为日期,后面为序号。那么我们要做的第一件事是拼接这三段字符。MySQL中的拼接函数还记得吗?

concat函数

concat的用法

比如

select concat('A', 'B', 'C');

在这里插入图片描述

日期相关函数

now()获取当前日期

获取当前日期,用法:

select now();

在这里插入图片描述

date_format(日期,指定格式) 格式化日期

格式化日期,用于指定查到的日期格式,比如我们流水号中的年月日,比如:

select date_format(now() , '%Y%m%d');

结果是:
在这里插入图片描述

lpad(需填充字符,填充后长度,填充字符串)

select lpad('A' , 4 , 0);

结果
在这里插入图片描述

那么现在结果很明显了,我们只需要拼接组合一下即可。

select concat('SP',date_format(now(),'%Y%m%d') , lpad('1' , 4 , 0));

在这里插入图片描述
如果需要实现后四位序号自增,该怎么实现?

我们可以先获取购物编号的后四位,+1。
然后再执行插入操作。

找出最大序号:

select concat('SP',date_format(now(),'%Y%m%d') , lpad(max(right(shoppingNum , 4)) + 1 , 4 , 0)) from mytest m 

然后再insert即可

insert  into mytest values(3,now(), (select concat('SP',date_format(now(),'%Y%m%d') , lpad(max(right(shoppingNum , 4)) + 1 , 4 , 0)) from mytest ));
  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值