订单号设计规则

最近公司由于业务的需要,设计生成订单号规则(定制版)。在网上查看了一些资料,在这里总结一些自己的心得。

  1. 基本需求:正确性、唯一性、安全性、稳定性
  2. 高级需求:检索性能、其他性能方面
  3. 定制化需求:语义相关、业务相关

订单号的生成规则:

  •  唯一性(不重复):保证编码id唯一;
  • 安全性:在编码中不要加入任何和公司运营的数据;
  •  易读性:不大规模使用随机码,造成编码位数过长,不建议有字母编码规则,最好是纯数字编码;
  • 可扩展性:便于查询,业务升级等;
  • 防止并发:主要针对编码中有时间的设定,分布式机器的时间不统一。

 

编码规则一般位数控制在10-15位,常见的编码规则:

  • 时间戳+业务类型+下单平台+随机码(或自增码,自增码每天可清零)+支付渠道+用户ID(建议);
  • 年月日时分秒+用户ID;
  • 年月日时分秒微秒+随机码(2)+流水号+随机码(3);
  • 利用数据库主键值产生一个自增长的订单号(订单号即数据表的主键)
  • 日期+自增长数字的订单号(比如:2012040110235662)
  • 产生随机的订单号(65865325365966)
  • 字母+数字字符串式,字母有包含特别意义,C02356652
  • Twitter的雪花算法,php第三方扩展库(php-snowflake):https://github.com/zh-ang/php-snowflake(推荐)

转载于:https://www.cnblogs.com/anly95/p/10516673.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值