业务编号生成器

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了业务编号生成器相关的知识,希望对你有一定的参考价值。

在我们实际做项目的过程中,时常需要生成一些跟业务相关的一些唯一的业务编号,这些编号又需要一定的规则,一般是每生成一个新的编号是在前一个编号的集成上尾号递增1个单位,下面是我业余时间写的一个编号生成器,直接贴代码:

/**

* 唯一业务编号生成器

* @param flag 业务前缀标识

* @return

* @throws Exception

*/

public synchronized String getBusinessNum(String flag) throws Exception{

DateFormat dFormat = new SimpleDateFormat("yyyyMMdd");

String dateNum = dFormat.format(new Date());

String value = RedisSlave.getInstance().getString(dateNum);

//如果当天还未产生过一个编号

int count;

if(StringUtils.isEmpty(value)){

count = 1;

RedisSlave.getInstance().set(dateNum, count+"", 86400);

}else{

count = Integer.parseInt(value);

}

String zero = "";

if(count <10){

zero = "00000";

}else if(count>9 && count<100){

zero = "0000";

}else if(count>99 && count<1000){

zero = "000";

}else if(count>999 && count<10000){

zero = "00";

}else if(count>9999 && count<100000){

zero = "0";

}

String afterNum = dateNum + zero + count;

count++;

RedisSlave.getInstance().set(dateNum, count+"", 86400);

         /**

          *RedisSlave.getInstance().setNX(key, value, 86400);

          *这个方法是如果key已经存在了就不能插入新的value了

         */

return flag + afterNum;

}


本文出自 “Flyfish” 博客,请务必保留此出处http://9381188.blog.51cto.com/9371188/1876848

以上是关于业务编号生成器的主要内容,如果未能解决你的问题,请参考以下文章

如何使用redis生成唯一编号及原理

mysql生成不重复随机数(unique number generation)

SQL Server 存储过程生成流水号

关于后台系统自动生成的一点思考

关于后台系统自动生成的一点思考

关于后台系统自动生成的一点思考