RedisTemplate序列号自增id(当前日期+序列号)

参照 https://blog.csdn.net/weixin_42851487/article/details/82842055

@Autowired
private RedisService redisService;

测试实例

redisService.getSerialBizId("CG","yyyyMMddHH",5)

/**
 * 生成单据号
 * @param prefixBizCode
 * @param timeFormatter
 * @param numLength
 * @return
 */
public String getSerialBizId(String prefixBizCode, String timeFormatter, int numLength) {
   String serialNumLength="";
   for(int i=0; i<numLength; i++){
      serialNumLength+="0";
   }
   if(StringUtil.isEmpty(timeFormatter)){
      timeFormatter="yyyyMMddHHmmss"; //yyyyMMddHHmmss
   }
   //默认序列号位数
   if(StringUtil.isEmpty(serialNumLength)){//默认
      serialNumLength="000000";
   }

   SimpleDateFormat sdf=new SimpleDateFormat(timeFormatter);
   Date date=new Date();
   String formatDate=sdf.format(date);
   String key= prefixBizCode+formatDate;
   Long incr = getIncr(key, getCurrent2TodayEndMillisTime());
   if(incr==0) {
      incr = getIncr(key, getCurrent2TodayEndMillisTime());//从000001开始
   }

   DecimalFormat df=new DecimalFormat(serialNumLength);//流水号位数
   return prefixBizCode+formatDate+df.format(incr);
}

/**
 *  根据key获取redis值
 * @param key
 * @param liveTime
 * @return
 */
public Long getIncr(String key, long liveTime) {
   RedisAtomicLong entityIdCounter = new RedisAtomicLong(key, redisTemplate.getConnectionFactory());
   Long increment = entityIdCounter.getAndIncrement();

   if ((null == increment || increment.longValue() == 0) && liveTime > 0) {//初始设置过期时间
      entityIdCounter.expire(liveTime, TimeUnit.MILLISECONDS);//单位毫秒
   }
   return increment;
}

/**
 * 系统日期的毫秒数
 * @return
 */
public Long getCurrent2TodayEndMillisTime() {
   Calendar todayEnd = Calendar.getInstance();
   // Calendar.HOUR 12小时制
   // HOUR_OF_DAY 24小时制
   todayEnd.set(Calendar.HOUR_OF_DAY, 23);
   todayEnd.set(Calendar.MINUTE, 59);
   todayEnd.set(Calendar.SECOND, 59);
   todayEnd.set(Calendar.MILLISECOND, 999);
   return todayEnd.getTimeInMillis()-new Date().getTime();
}
上一篇:将记录按小时或按日分组,并在mysql中填充零或空的空白


下一篇:java格式化时间到毫秒