java生成流水号,例如(XXX201801230001)

别等时光非礼了梦想. 提交于 2019-11-29 05:36:17

生成的流水号格式:字符串+"转换后的时间串"+多少位的流水号。

/**
* @Title: createCode 
* @Description: TODO(生成流水号[前缀+日期+流水号]) 
* @param prefix 前缀
* @param dateStr 日期串
* @param length 流水号长度 length要大于0
* @return 
* @author XXX 2018年1月8日 下午5:53:52
*/
public static String createCode(String prefix,String dateStr,int length){
StringBuffer code = new StringBuffer();
if((prefix != null && !prefix.equals("")) || (dateStr != null && !dateStr.equals(""))){
if(prefix != null && !prefix.equals("")){
code.append(prefix);
}
if(dateStr != null && !dateStr.equals("")){
code.append(dateStr);
}
synchronized (code) {
ApplicationContext ac=new ClassPathXmlApplicationContext("applicationContext.xml");
SerialNumberService ser = (SerialNumberService) ac.getBean("serialNumberService");
SerialNumber serialNumber = new SerialNumber();
serialNumber.setPrefix(prefix);
serialNumber.setDateStr(dateStr);
serialNumber.setLength(length);
SerialNumber serialNumber_ = ser.getSerialNumber(serialNumber);
Integer seq = null;
if(serialNumber_ != null) {
seq = serialNumber_.getSeq();
System.out.println("seq:"+seq);
}
if(seq == null){
seq = 1;
serialNumber.setSeq(seq);
ser.addSerialNumber(serialNumber);
}else{
seq++;
serialNumber.setSeq(seq);
ser.updateSerialNumber(serialNumber);
}
if(length > 0){
code.append(String.format("%0"+length+"d", seq));
}else{
code.append(seq);
}
}
}
return code.toString();
}

流水号表:

CREATE TABLE "SYS_CODE_FACTORY" 
   ( "PREFIX_" VARCHAR2(20), 
"DATESTR" VARCHAR2(25), 
"SEQ" NUMBER(*,0), 
"LENGTH" NUMBER(38,0)
   );
 
  ALTER TABLE "SYS_CODE_FACTORY" ADD PRIMARY KEY ("PREFIX_", "DATESTR", "LENGTH");
 
   COMMENT ON COLUMN "SYS_CODE_FACTORY"."PREFIX_" IS '流水号前缀';
 
   COMMENT ON COLUMN "SYS_CODE_FACTORY"."DATESTR" IS '时间格式';
 
   COMMENT ON COLUMN "SYS_CODE_FACTORY"."SEQ" IS '流水号数字编号';
 
   COMMENT ON COLUMN "SYS_CODE_FACTORY"."LENGTH" IS '流水号的数字编码长度';
 
   COMMENT ON TABLE "SYS_CODE_FACTORY"  IS '流水号表';

源码下载

http://download.csdn.net/download/qq_30270931/10202554

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!