likai
V2EX  ›  PHP

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

  •  
  •   likai · Aug 26, 2015 · 4225 views
    This topic created in 3918 days ago, the information mentioned may be changed or developed.
    不知道怎么表达
    现在是有客户这样一个要求。

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

    求个思路
    PHP+mysql

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

    达到 999 或者第 2 天一到就 truncate 一下临时表,就又从 1 开始了
    yangqi
        2
    yangqi  
       Aug 26, 2015
    编号每天重复?这个在 php 里做
    yangqi
        3
    yangqi  
       Aug 26, 2015
    @holystrike 为什么不直接在原表里取当天的最大编号,然后程序里自增。临时表多此一举啊
    moro
        4
    moro  
       Aug 26, 2015
    试试触发器
    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  
       Aug 26, 2015 via Android
    @yangqi 防止并发出问题,临时表不用弄唯一索引及插入失败的处理了。

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

    或者根本不设置这个序号字段,增加一个创建时间字段 createtime ,不限制每天插入的数据量,也不需要锁了,在数据获取的程序那里处理一下, select 的时候 order by createtime limit 999 ,然后展示的时候用 php 添加这个序号也行
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   1037 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 56ms · UTC 22:39 · PVG 06:39 · LAX 15:39 · JFK 18:39
    ♥ Do have faith in what you're doing.