V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
leben
V2EX  ›  程序员

请教关于单据号的算法

  •  
  •   leben · 2013-04-26 21:03:39 +08:00 · 4029 次点击
    这是一个创建于 4227 天前的主题,其中的信息可能已经有所发展或是发生改变。
    企业管理软件里面的单据号一般都是YYYYMMMDD+流水号。PHP+MySQL开发,考虑并发操作,怎么能确保流水号不重复,不缺号。求一个算法思路。
    以前用Delphi+Oracle局域网环境下,10-20人同时操作,会出现重复号码。
    10 条回复    1970-01-01 08:00:00 +08:00
    bhuztez
        1
    bhuztez  
       2013-04-26 21:09:10 +08:00
    用 SELECT FOR UPDATE 卡住,一个个过 ...
    lookhi
        2
    lookhi  
       2013-04-26 21:14:38 +08:00
    redis incr
    marchtea
        3
    marchtea  
       2013-04-26 23:34:43 +08:00
    用transaction控制..这种反正不用考虑效率,正确性最重要。
    ljbha007
        4
    ljbha007  
       2013-04-26 23:58:23 +08:00
    专门放个字段存流水号
    然后每次先不管单据号直接插入数据
    插完之后在select出来流水号 然后把单据号更新上去就行了
    或者干脆就不要单据号这个字段 直接每次使用单据号的时候就把创建日期和流水号拼起来就行了
    ewangke
        5
    ewangke  
       2013-04-27 00:15:38 +08:00
    这是业务问题吧?怎么当成技术问题了?
    keakon
        6
    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
        7
    nsxuan  
       2013-04-27 00:58:41 +08:00 via iPad
    MySQL 自增不就可以了吗
    gamexg
        8
    gamexg  
       2013-04-27 07:56:03 +08:00
    一个表专门放日期和指定日期最大的单据号。
    wjcody
        9
    wjcody  
       2013-04-27 11:28:13 +08:00
    取自增id做后缀可以不重复
    sarices
        10
    sarices  
       2013-04-27 11:47:38 +08:00
    做个号码池,先进先出
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   4506 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 05:36 · PVG 13:36 · LAX 21:36 · JFK 00:36
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.