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

请教一个设置一个 MYSQL 自增字段为 001-999 这种?

  •  
  •   likai · 2015-08-26 11:19:53 +08:00 · 3743 次点击
    这是一个创建于 3170 天前的主题,其中的信息可能已经有所发展或是发生改变。
    不知道怎么表达
    现在是有客户这样一个要求。

    提交数据。然后生成一个 001-999 的递增编号;
    以天为条件。
    每天第一个提交数据的编号为 001 ,以此类推。直到 999

    求个思路
    PHP+mysql

    目前想到的方法是写入数据库之前判断前一条数据,有其它简单的方法么?
    9 条回复    2015-08-26 13:51:57 +08:00
    holystrike
        1
    holystrike  
       2015-08-26 11:25:18 +08:00
    另外建个临时表,包含一个自增字段和一个对这个业务表的外键字段,
    先在临时表里创建记录,取得自增号,再把这个号存到业务表

    达到 999 或者第 2 天一到就 truncate 一下临时表,就又从 1 开始了
    yangqi
        2
    yangqi  
       2015-08-26 11:29:26 +08:00
    编号每天重复?这个在 php 里做
    yangqi
        3
    yangqi  
       2015-08-26 11:33:06 +08:00
    @holystrike 为什么不直接在原表里取当天的最大编号,然后程序里自增。临时表多此一举啊
    moro
        4
    moro  
       2015-08-26 12:00:14 +08:00
    试试触发器
    CREATE EVENT event1
    ON SCHEDULE
    EVERY 1 DAY STARTS '2015-08-01 00:00:00'
    DO
    alter table test auto_increment=100000
    gamexg
        5
    gamexg  
       2015-08-26 12:00:36 +08:00 via Android
    @yangqi 防止并发出问题,临时表不用弄唯一索引及插入失败的处理了。

    每天一个临时表更省事,每天切换时不用考虑锁。
    moro
        6
    moro  
       2015-08-26 12:05:35 +08:00
    每天 Memcached::add 一个 key
    然后 Memcached::increment 就可以了
    loginv2
        7
    loginv2  
       2015-08-26 13:36:35 +08:00
    wd0g
        8
    wd0g  
       2015-08-26 13:45:43 +08:00
    ①--------------------------------------------
    实际上就增加一个字段,开始的天字段
    比如这条记录是 8/26 号创建的,那么该记录的该字段就是 8/26
    然后用以后的天数减去字段中的天数
    ②--------------------------------------------
    增加一个关系表
    |---id----|---天数---|
    feiyuanqiu
        9
    feiyuanqiu  
       2015-08-26 13:51:57 +08:00
    @gamexg 并发就并发呗,直接上锁,一天才 999 条数据,并发不是问题

    或者根本不设置这个序号字段,增加一个创建时间字段 createtime ,不限制每天插入的数据量,也不需要锁了,在数据获取的程序那里处理一下, select 的时候 order by createtime limit 999 ,然后展示的时候用 php 添加这个序号也行
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   874 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 21:03 · PVG 05:03 · LAX 14:03 · JFK 17:03
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.