请教关于单据号的算法

2013-04-26 21:03:39 +08:00
 leben
企业管理软件里面的单据号一般都是YYYYMMMDD+流水号。PHP+MySQL开发,考虑并发操作,怎么能确保流水号不重复,不缺号。求一个算法思路。
以前用Delphi+Oracle局域网环境下,10-20人同时操作,会出现重复号码。
4025 次点击
所在节点    程序员
10 条回复
bhuztez
2013-04-26 21:09:10 +08:00
用 SELECT FOR UPDATE 卡住,一个个过 ...
lookhi
2013-04-26 21:14:38 +08:00
redis incr
marchtea
2013-04-26 23:34:43 +08:00
用transaction控制..这种反正不用考虑效率,正确性最重要。
ljbha007
2013-04-26 23:58:23 +08:00
专门放个字段存流水号
然后每次先不管单据号直接插入数据
插完之后在select出来流水号 然后把单据号更新上去就行了
或者干脆就不要单据号这个字段 直接每次使用单据号的时候就把创建日期和流水号拼起来就行了
ewangke
2013-04-27 00:15:38 +08:00
这是业务问题吧?怎么当成技术问题了?
keakon
2013-04-27 00:26:07 +08:00
我也是用 redis,其实就几行代码:

def get_next_id(for_type, redis_client):
return redis_client.hincrby('next_id', for_type)

重点是 redis 是单线程的。
nsxuan
2013-04-27 00:58:41 +08:00
MySQL 自增不就可以了吗
gamexg
2013-04-27 07:56:03 +08:00
一个表专门放日期和指定日期最大的单据号。
wjcody
2013-04-27 11:28:13 +08:00
取自增id做后缀可以不重复
sarices
2013-04-27 11:47:38 +08:00
做个号码池,先进先出

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/67100

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX