天天看點

【原】Redis實作生成自增流水号

場景:

      公司内部有個業務場景是背景稽核之後需要生成一個流水号,規則是: 201807280001,201807280002,201807280003,後面四位依次遞增,前面年月日取目前時間并且轉換成yyyymmdd格式。

      于是想到redis比較适合做這種,而且因為是基于記憶體操作,速度比較快,不占用資料庫資源,于是通過搜集整理出代碼如下:

@Override
    public String generate(String bizCode) {
        //** 擷取今天的日期:yyyyMMdd *//*
        String date = com.i2p.util.DateUtils.getCurentDate();
        String key = "serial.number:" + date;
        //** 自增 *//*
        long sequence = this.incr(key);
        String seq = SequenceUtils.getSequence(sequence);
        StringBuilder sb = new StringBuilder();
        sb.append(bizCode).append(seq);
        String serial = sb.toString();
        return serial;
    }
      
package com.i2p.util;

public class SequenceUtils {

    static final int DEFAULT_LENGTH = 4;
    public static String getSequence(long seq) {
        String str = String.valueOf(seq);
        int len = str.length();
        if (len >= DEFAULT_LENGTH) {// 取決于業務規模,應該不會到達4
            return str;
        }
        int rest = DEFAULT_LENGTH - len;
        StringBuilder sb = new StringBuilder();
        for (int i = 0; i < rest; i++) {
            sb.append('0');
        }
        sb.append(str);
        return sb.toString();
    }
}      
/**
     * 得到系統目前日期
     * "yyyyMMdd"
     */
    public static String getCurentDate() {
        SimpleDateFormat tempDate = new SimpleDateFormat("yyyyMMdd");
        String datetime = tempDate.format(new java.util.Date());
        return datetime;
    }