系统中生成编号/单号问题的实现方案讨论

应用场景

场景:对于大多数电商系统或财务系统来说,系统中的单号一般都不是从1开始的自增数字,而是一串有一定意义的字符串序列。 而往往这样的单号是要全局唯一的,不可重复。 那么,每次新增订单记录时,这个单号就要按照指定的规则来生成。

常见的订单号规则是字母前缀+日期+时间+定长的数字,如DD201610201559060001(format:XXYYYYMMDDHHmmssNNNN),PZ16102015000012(format:XXYYMMDDHHNNNNNN)

常见方案...

实现这样的场景,有如下几种方案:

1. 常规实现方案:代码逻辑为从数据表里取出现有最大订单号,转换后得到新的订单号,将新的订单insert到表里。
2. 考虑并发,在1的基础上,加lock,以避免多个线程同时执行这段逻辑,导致订单号重复引起主键冲突
3. 对于2来说,这种方案仅适用于单应用部署的情况。 像电商的订单表,往往是好多系统都要生成订单, 那么,最终到数据库层级时, 也仍然会导致订单号重复引起主键冲突。 所以,要做数据库级别的锁表和事务控制。
4. 方案3的另一个版本:将生单逻辑从各业务系统解耦,封装起来单独部署。 然后提供rpc,供各业务系统调用。 这种方案的缺点是,单点部署会有风险。

比较以上方案,1显然是最基本的方案,当有并发时,2和4解决了单节点部署的并发问题,3解决了多多节点部署下的并发问题。

我的上一篇博客里有详细的方案说明。

完美方案

这里要介绍的是另一个方案——**从更细粒度的角度,将单号的生成抽象出来**。

具体怎么实现? 见下面的方案:

**分离单号的生成和使用**

以日期为粒度,日终批量生成下一天的所有单号,暂存到一个单号表T_Sequence(seq varchar(64),primary key(seq))里。
次日系统有订单时,直接从这个单号表里取出一个订单号,作为新订单记录的订单号。注意,这里要说的是,取出这个订单号之后,就把这个单号从T_Sequence表里删掉, 这样可以保证每次订单号不重复。

对于这个方案,只要保证每天的订单号事先生成完成就行了,这一点很容易做到。 另外,所谓每天有多少订单号,这个需要程序员自己评估,然后得出一个保守的量。 当然,不考虑系统每日订单量,就直接确定一个保守值也没问题,比如1百万。 每天的日初删掉前日的单号即可。

这样一来,解决了单号重复问题,也极大提高了系统的性能。

**方案再次优化,利用Sequence**

oracle是支持Sequence的。 我的系统用的db是SqlServer。 今天通过和一个dba沟通,才得知SqlServer从2012以后,已经支持Sequence了, 这样的话,就可以直接读取Sequence的递增值,然后按照规则得到新增记录的订单号。 这个方案就无需对单号的生成和使用做分离了,也无需那些批处理服务了——这应该是最优方案了。

CREATE SEQUENCE [dbo].[Sequence-20161020-180217]
AS [BIGINT]
START WITH 1
INCREMENT BY 1
CACHE
GO

SELECT NEXT VALUE FOR [Sequence-20161020-180217]

不用Sequence也行,看这位仁兄的博客-[一种在SQLServer中实现Sequence的高效方法](http://www.cnblogs.com/heekui/archive/2008/07/24/1250842.html), 或者这位仁兄的博客-[自已写的存储过程用来解决自动生成编号问题](http://blog.sina.com.cn/s/blog_638d83240100xvz1.html)



我的有底线的



系统中生成编号/单号问题的实现方案讨论

时间: 2024-12-11 11:12:25

系统中生成编号/单号问题的实现方案讨论的相关文章

中通快递-单号查询接口-物流路由跟踪信息快递鸟api对接教程

前言 看完快递鸟api对接教程这篇文章,然后把源码复制到你的项目上,就能快速完成中通快递接口对接.更适合刚入门的菜鸟,调用快递鸟的中通快递查询API接口,能查询到中通快递单号从收件.运输,到转运中心,派送到签收等各个环节的物流发货状态.快递鸟api接口不区分开发语言,支持Java,C#,PHP,Python,ObjectC等开发语言的程序调用.下面具体讲解实现过程. 目录 1.完成前期准备工作 2.API接口 3.请求参数(Headers) 4.请求参数(Body) 5.返回参数(Return)

Python sphinx-build在Windows系统中生成Html文档

看到前同事发布的"Markdown/reST 文档发布流水线"基于TFS.Docker.Azure等工具和平台进行文档发布的介绍说明,不得不在心中暗暗竖起大拇指.这套模式,实现了文档编写后版本管理.发布.存档.分享的高度自动化,它不仅仅可以应用在文章中介绍的技术文档发布模式,同样也适用于我们大多数web.app等软件生命周期过程模式.DevOps一词的盛行,绝对不是软件行业中又一个流行语的鼓吹和炒作,而是软件过程的一种发展和进化.结合自动化平台.Docker.云平台等优秀技术和产品.软

系统中生成二维码

平台使用方式:先将把2个DLL文件(FWFramework.Client.QRCode.dll,ThoughtWorks.QRCode.dll)拷贝到客户端目录.文件下载:http://bbs.delit.cn/forum.php?mod=attachment&aid=NjM5fDM0YmRhZGU1fDE0NDg4Njk3NjR8MHwzNzk%3D 1.生成二维码'实例化(类似NEW)dim qrcode=LoadAssembly("FWFramework.Client.QRCode

生成最大单号 scope_identity

-- 假定要给T_0101001创建一个Sequence -- 创建表SeqT_0101001 create table SeqT_0101001( -- ID列为自增列 SeqID int identity(1,1) primary key, -- Sequence值 SeqVal varchar(1) ) -- 创建从SeqT_0101001表获取最新Sequence值的存储过程 create procedure P_GetNewSeqVal_SeqT_0101001 as begin --

幂等和高并发在电商系统中的使用

在Java web项目开发中,经常会听到在做订单系统中生成订单的时候,要做幂等性控制和并发控制,特对此部分内容作出总结,在高并发场景下,代码层面需要实现并发控制:但是幂等性,其实更多的是系统的接口对外的一种承诺,承诺一次请求和多次请求会返回同样的数据.关于幂等性将分别从高等代数中的幂等性.HTTP中的幂等性和订单生成系统中的幂等性阐述:并发性控制则提供了分布式锁等方式来对并发场景进行代码实现. 一.幂等性 idempotence  ['a?d?mpo?t?ns] 1.高等代数中关于幂等idemp

工单在客服系统中的应用

从国内来看,目前企业的线上客服主要有 三种模式,在线客服.机器人客服.工单.前者是基于人工坐席会话的基础上,提供一对一的即时聊天会话,即时接起客户服务请求,后者则可适用于离线处理. 在线客服是国内目前应用非常广泛的服务模式,但也因为服务成本高,服务水平参差不齐而为企业诟病.机器人客服在很大程度上能够缓解客服人员的压力,同时标准化的客户会话语术,能有效减少因沟通过程中带来的理解误差以及因客服人员语气或态度差带来的客服投诉. 工单最常见于IT运维支持,如用于处理内部员工的设备报障问题.采购需求等.用

多功能PCIE交换机之九:单NT系统中需要注意的问题

多功能PCIE交换机之九:单NT系统中需要注意的问题 1.单NT与双NT系统差异 NTB通常用在双控或者多控的系统上,用来实现跨节点的数据传输.在由多个节点构成的系统上,通常每个节点上都有一个NTB芯片,以实现全系统地址空间划分和路由.顾名思义,单NT是指用一个PCIE非透明桥来实现节点间数据传输的方案,通常用在两个节点之间.和多NT的系统相比,这种方法实现相对比较简单,成本较低,开发周期较短,能够缩短整个系统的关键功能和性能的验证周期. 2.单NT系统的实现 单NT的实现需要结合整个系统的设计

PHP 通过单号查询快递( 申通、EMS、顺丰、圆通、中通、韵达、天天、汇通、全峰、德邦、宅急送)

<?php header('content-type:text/html;charset=utf-8'); /** * @param $url String * @param array $post * @param array $options * @return mixed at most json */ function curl_get($url, array $post = NULL, array $options = array()) { $defaults = array( CUR

DVB系统中PCR的生成和PCR校正

http://blog.csdn.net/chenliangming/article/details/3616720 引自<广播电视信息>2008年1月 从数字电视前端系统功能上来讲,传统的DVB数字硬件前端技术包含编码.复用.加扰.调制四个基本环节,而在实际的DVB前端系统中还有直接的TS流转发环节,如下图所示: 上图中编码环节是将模拟视音频或者基带的数字视频和音频信号编码形成标准的TS流,而流转发环节是将卫星或者通过其它信道过来的信号转成符合当地标准的TS流,所有的TS进入复用环节进行复用